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1.0 INTRODUCTION 

The WD10C01A is a VLSI Winchester/Optical 
Disk Controller chip that provides the data han- 
dling and control for intelligent disk applications. 
The WD10C01A interfaces to nearly any serial 
disk interface, including ST412, ST412HP, ESDI, 
SMD, and many optical disk interfaces. The 
WD10C01A provides great flexibility in format 
design, allowing for multiple ID fields, special 
synchronization requirements, special information 
fields, or almost any other special requirement. 
The WD10C01A can provide all of the data, 
status, and control signals required by these inter- 
faces. 



1.1 FEATURES 

• Disk interfaces and formats supported include 
ST412, ST412HP, ESDI, SMD and optical disks 

• Full multi-sector operation with four byte ID 
auto-increment 

• Up to 24 mbit/second maximum transfer rate 

• Supports 16-bit CRC-CCITT polynomial on ID 
field 

• Degree 5 and 6 Reed-Solomon ECC with 3- or 
5-way interleave to protect data field against 
long error burst 

• Provides composite syndromes for error 
correction 

• Up to 1 :1 interleave operation 

• Writeable control store allows flexible error 
Recovery, including redundant ID and sync 
fields 
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FIGURE 1-1. WD10C01A PIN DIAGRAM 



• Support hard or soft sector formats, sector size 
to 1 250 bytes when 5-way interleave is used 
for degree 5 Reed-Solomon code 

• Built in crystal driver for data rate and/or CPU 
use 

• Generic non-multiplexed CPU interface with 
maskable interrupts 

• Separate CPU and disk data busses 

• On-the-fly compare against buffer data 

• 20 general I/O Lines for disk drive control 

• 68-Pin PLCC package 
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2.0 GENERAL DESCRIPTION 

The WD10C01A has separate ports for data DMA 
transfer and for the microprocessor to achieve a 
maximum performance. 

The WD10C01A performs the disk data serializa- 
tion and de-serialization. It can interface with 
various magnetic and optical Data En- 
coder/Decoders (ENDEC). The data format on the 
disk is controlled by a Writeable Control Store. It 
is very flexible with the capability to support 
various formats including optical disk. The device 
also has the capability to compare data and verify 
the ECC. The WD10C01A can perform full track 
operations without CPU intervention using the 
Writeable Control Store, auto-incrementing ID 
registers and the sector counter. 

The WD10C01A includes logic implementing 
CCITT-CRC and Reed-Solomon ECC for data 
protection. The ID field is protected by sixteen bit 
CRC and the data field is protected by degree five 
or six RS-ECC. The user can also select the inter- 
leave factor of three or five for the data field. The 
term "interleave" here should not be confused 
with the term "sector interleave," which defines 
the relation between the physical and the logical 
location of sectors within a track. Interleaving the 
data field means spreading the data across 
several ECC code words to improve the capability 
for correcting longer error bursts. 

For the error correction, the WD10C01A 
generates the composite syndromes. From this 
error information, the correction software can 
generate individual syndromes to correct up to 
two error bytes per interleave (for degree 5) or up 
to three error bytes per interleave (for degree 6). 
Optionally, the user can use external, more 
powerful ECC device, such as WD60C80. 



The highly programmable nature of the 
WD10C01A allows the use of redundant ID and 
data sync fields within a single sector. This fea- 
ture, along with the programmable degree 5 or 6 
RS-ECC, gives the WD10C01A a greater 
capability for recovering user data in a sector with 
'grown' defects. 

The WD10C01A interfaces to the buffer manager, 
such as WD60C40 through an eight bit DMA port. 
It us es as ynchronous protocol through 
DREQ/DACK signals. 

The WD10C01A has a generic microprocessor in- 
terface that allows the WD10C01A to be used 
with all popular 8-bit microprocessors. The 
WD10C01A has interrupt capability, which frees 
up the microprocessor from constantly polling the 
device status. The WD10C01A also has a built-in 
crystal oscillator driver that can be used to 
generate data reference, buffer management, or 
microprocessor clocks. Two separate outputs are 
provided with internal programmable dividers. 
Both outputs have the extra drive voltage and cur- 
rent necessary for driving MOS microprocessor 
clock inputs. 

The WD10C01A has 20 lines dedicated to exter- 
nal I/O ports that the microprocessor can use to 
control the drive and head select lines, seek com- 
mand and drive status. Eight lines are output only, 
six lines are input only, and four other lines can be 
individually programmed for input or output. Two 
other latch and hold input lines are tied to the 
interrupt logic and can be used to detect fault and 
ready conditions without constantly polling the 
device. 
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4.0 SIGNAL DESCRIPTION 

The WD10C01 A is a 68-pin PLCC device. 

The following section describes the external sig- 
nals available on the WD10C01A. Conventions 
are as follows: 

I indicates that a signal is an input to the 
WD10C01A. 

O indicates that a signal is an output from 
theWD10C01A. 



I/O indicates that a signal is bidirectional. 

1,0 indicates that a signal can be input 
output. 

* as a suffix indicates an active low signal; 
however, most drawings and text use an 
overscore to indicate an active low signal. 



PIN 


MNEMONIC 


I/O 


DESCRIPTION 


25-21 


A0-A4 


I 


CPU ADDRESS BUS. These signals are used to address internal 
WD10C01 A registers. 


36 


CPUCLK 





CPU CLOCK OUTPUT. This is the OSC output (see below) 
divided by two or three, selected by an internal register. This out- 
put has extra drive for use with certain microprocessors. 


10 


CS 


I 


CHIP SELECT. This active low signal enables the WD10C01 A bus 
interface logic. 


11-18 


DB0-DB7 


I/O 


CPU DATA I/O BUS. This data bus is used to transfer data be- 
tween the CPU and the WD1 0C01 A. 


27 


INT 





CPU INTERRUPT. This active low, open drain output is asserted 
whenever an enabled interrupt condition occurs on the 
WD10C01A. 


33 


OSC 


o 


OSCILLATOR OUTPUT. The 1x crystal oscillator output, optionally 
divided by two. This signal has the same drive capability as 
CPUCLK. 


19 


RD 


I 


CPU READ STROBE. This active low signal enables data from 
the WD10C01 Aon to the CPU data bus. 


61 


RST 


I 


RESET. This active low signal resets all internal circuits that must 
be reset at power on. A complete list is given later in this docu- 
ment. The reset is latched and the condition must be cleared by 
the CPU. 


20 


WR 


I 


CPU WRITE STROBE. This active low signal strobes data into the 
selected WD10C01 A register from the CPU data bus. 


37 


X1 


I 


CRYSTAL DRIVER INPUT. X1 can also be driven by an external 
clock. 


38 


X2 





CRYSTAL DRIVER OUTPUT. 



TABLE 4-1. CPU INTERFACE 
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PIN 


MNEMONIC 


I/O 


DESCRIPTION 


67 


ACKA 


I 


BUFFER DATA ACKNOWLEDGE. This active low signal indicates 
to the WD10C01 A that data can now be transferred to or from the 
data buffer. 


8-1 


BMDO-7 


I/O 


BUFFER MEMORY DATA BUS. This is an eight bit data bus that 
interfaces the WD10C01 A with the disk data buffer memory. 


68 


BMDP 


I/O 


DATA BUS PARITY. This signal is used to generate and check 
parity with the disk data buffer memory. 


66 


REQA 





BUFFER DATA REQUEST. This signal is asserted when the 
WD1 0C01 A has data to write to the data buffer, or needs data 
from the data buffer. 



TABLE 4-2. BUFFER INTERFACE 



PIN 


MNEMONIC 


I/O 


DESCRIPTION 


30 


AMDET 


I 


ADDRESS MARK DETECTED. Used only in ST412 type inter- 
faces that use missing clocks or other qualifiers to the sync bytes 
that mark the start of a field. 


31 


AMENA 





ADDRESS MARK ENABLE. Used to write a missing clock sync 
byte (ST412) or soft sector mark (ESDI, SMD) on the media. 


65 


NRZI 


I 


NRZ READ DATA IN. Serial data input from the disk phase-locked 
loop. This signal is clocked in by the rising edge of RRCLK. 


63 


NRZO 





NRZ WRITE DATA OUT. Serial data output. NRZO is valid on the 
rising edge of WRCLK. 


59 


RG 


o 


READ GATE. Active when reading from the disk drive. This signal 
is turned off for one byte time on an ID search error to reset exter- 
nal data decoders. 


64 


RRCLK 


I 


READ/REFERENCE CLOCK. This is the reference clock used to 
set the data rate for write, and is the recovered clock for read. The 
switching must be glitch free. NRZI is clocked into the WD10C01 A 
by the rising edge of this clock. 


32 


SEQOUT 





SEQUENCER OUTPUT. This signal is a user definable output bit 
that is set up in the control byte of the sequencer control store 
(see below). This signal can be used to control an external ECC 
generator and checker, and is byte aligned with both read and 
write data. 


58 


WG 





WRITE GATE. Active when writing to the disk drive. 


62 


WRCLK 





WRITE CLOCK. This is output during write for drives that require 
it. NRZO data is valid on the rising edge of this clock. 



TABLE 4-3. DISK DATA INTERFACE 
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PIN 


MNEMONIC 


I/O 


DESCRIPTION 


35 


COMPLT 


I 


COMPLETE. This signal Is used to detect function complete condi- 
tions, such as seeks or status requests. The signal only generates 
a CPU interrupt, and does not interfere with a read or write opera- 
tion. 


34 


DRVFLT 


I 


DRIVE FAULT. This signal is used to detect faults from the drive. 
The signal only generates a CPU interrupt, and does not interfere 
with a read or write operation. 


29 


INDEX 


I 


INDEX. This signal is used to indicate the start of a track. This sig- 
nal is latched for CPU status and interrupt. 


57-50 


PXO-7 





PORT X. This general purpose output port is intended for use as 
drive select and head select signals. 


49-46 


PYO-3 


l,0 


PORT Y. This general purpose port is intended for use as other 
control outputs or inputs. Each bit is selectable as input or output, 
but all bits are initialized to input when the WD10C01A is reset. 


45,44, 
42-39 


PZO-5 


I 


PORT Z. This general purpose input port is used to receive drive 
status signals. 


28 


SECTOR 


I 


SECTOR MARK. This signal is used for marking sector start loca- 
tions on the media. This can either be a hard sector mark, or a soft 
mark written on the media using AMENA (ESDI or SMD). 



TABLE 4-4. DISK CONTROL INTERFACE 



PIN 


MNEMONIC 


I/O 


DESCRIPTION 


26,60 


VDD 


I 


+5 VOLTS DC. 


9,43 


VSS 


I 


GROUND. 



TABLE 4-5. DEVICE POWER 
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5.0 ARCHITECTURE 

The WD10C01 A consists of the functional blocks 
shown in the block diagram in Figure 3-1. VDD 
and VSS are applied to the device through two 
separate pins each to improve noise immunity. 
The top and left hand sides of the diagram show 
CPU interface features, the right hand side shows 
disk interface features, and the bottom shows 
buffer interface features. These blocks are dis- 
cussed in the following paragraphs. 

The PORT DECODE block generates the 28 write 
strobes and 25 read strobes used by the 
microprocessor to access the various internal 
control and status ports. These include the inter- 
rupt registers, external disk control ports, control 
store, control store control, configuration, ECC 
control, and ID registers. 

The BUFFER CPU DATA block controls the trans- 
fer of data between the microprocessor and the 
internal registers. The direction control is qualified 
by chip select (CS) and read strobe (RD). 

The CPU CONFIGURATION PORTS are used to 
reset the WD10C01A, set the address mark 
enable timing, set the buffer interface timing, and 
select the frequency of the clock outputs, OSC 
and CPUCLK. 

The OSCILLATORS AND DIVIDERS block 
generates the clock outputs, OSC and CPUCLK, 
using an external crystal (or clock input) and 
dividers to select the frequency. Frequency selec- 
tion is glitch free. 

The INTERRUPT STATUS AND MASK registers 
are used to check and mask interrupts. The mask 
register does not affect the status register inputs. 
The interrupt sources include index and sector 
mark, drive fault and operation complete, ECC er- 
rors, and internal event status. 

The EXTERNAL PORTS are used to generate 
control signals and read status with the disk drive. 
Eight bits are output, six are input, and four are 
individually programmable for either input or out- 
put. 

The CONTROL STORE consists of 32 words of 
28 bits that are used to program the format of the 
disk sector. The data source, field length, error 
handling and checksum selection, and control sig- 



nals, like Read Gate and Write Gate, are control- 
led by the data stored here. 

The CONTROL STORE CONTROL determines 
the next address in the control store to use, 
whether the next sequential address or a jump to 
another address. This block includes the sector 
counter used for multi-sector commands. This 
block also includes the BIT RING COUNTER, 
which determines the timing of data transfers in 
theWD10C01A. 

The WAIT SEQUENCER handles searches for 
index, sector mark, address mark, and byte 
synchronization. 

The ID WRITE REGISTERS are 8 eight bit 
registers that are used to set the ID write field for 
format, or the search field for read/update write. 
Four of the registers are counters that auto-incre- 
ment during multi-sector commands. The other 
four registers do not increment, and are used for 
defect and flag information. The first byte of the 
four counters can be disabled for three byte ID 
fields. 

The ID READ REGISTERS are used to read the 
last ID read from the media to aid in defect han- 
dling. 

The ECD block performs the CRC on ID, selects 
the degree of RS-ECC with 3- or 5-way interleave 
on data fields, generates the checksum bytes, 
creates the composite syndromes and ECC error 
status necessary for the calculation of error loca- 
tion and mask. 

The VALUE register holds immediate data from 
the control store when generating gaps, sync 
fields, and address mark bytes. 

The SHIFT OUT register serializes internal or ex- 
ternal (buffer) data for writing on the disk. The 
output is multiplexed with the output of the check- 
sum register. 

The SHIFT IN register de-serializes the read data 
from the disk, clocked in by RRCLK. The data is 
also transferred to the checksum register for 
checking. 

The COMPARE block is used to compare incom- 
ing read data with an internal or external data 
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source. These include byte synchronization 
detection, ID field search, and buffer data com- 
pare. 

The BUFFER INTERFACE handles the fetching 
and writing of data with the external data buffer. 
This includes parity generation and checking, and 
data handshake with the buffer controller. 



5.1 ERROR CORRECTION AND 
DETECTION CODES 



5.1.1 CCITT-CRC 

The WD10C01A protects the ID fields using the 
CCITT-CRC code. The polynomial is defined as 
follow: 



9(x) 



x 16 + x 12 + x 5 + 1 



The user can select the initial state of the shift 
registers to be either all zero's or all one's. 



5.1.2 Reed-Solomon ECC 

The data fields are protected using the interleaved 
Reed-Solomon code operating on 8 bits symbols. 
The redundancy bytes are inverted. WD10C01A 
supports two polynomials of degree five and six. 
The generator polynomials operate in the finite 
field GF(256), which are defined as follow: 

Let B' re P resent elemer| ts of a finite field defined by a 
polynomial over GF(2): 

g(x) = x 8 + x 5 + x 3 + x 2 +1. 

The elements of the finite field employed by the 
codes are: 

a j = (p i)88 . 

The generator polynomials are self reciprocal and 
defined as follows: 

1 . Degree 5, distance 6: 

G(x) = (x+a 253 )*(x+a 254 )*(x+a°)*(x+a 1 )*(x+a 2 ). 



The coefficients of the polynomial in decimals are: 

1,60,183,183,60,1. 

2. Degree 6, distance 7: 

G(x) =(x+a 125 )*(x +a 126 )*(x +a 127 )*(x+a 128 )* 

(x + a 129 r(x + a 130 ). 

The coefficients of the polynomial in decimals are: 

1,176,126,163,126,176,1. 

The calculated checkbytes are inverted before 
they are written into the disk. During read opera- 
tion, the WD10C01A computes the composite 
syndromes by recalculating the checkbytes for the 
data field being read and compare them against 
the checkbytes written on the disk. The individual 
syndromes can be computed by dividing the com- 
posite syndromes with the factors of the generator 
polynomial: 

Si(x) = R(x) MODULO Gi(x) 

where: 

i =0..ecc degree -1. 

Si(x) = i'th individual syndrome. 

R(x) = composite syndrome. 

Gj(x) = factor of the generator polynomial, 
(x+a'). 

The WD10C01A supports two data interleaving 
factors. The user can optimize the performance 
by choosing the right degree and interleave com- 
bination. 

The following table shows the redundancy over- 
head and maximum field size. 



Interleave 
Factor 


Degree 5 


Degree 6 


Overhead* 


Max. Data* 
Field Size* 


Overhead* 


Max. Data* 
Field Size* 


3 


15 


750 


18 


747 


5 


25 


1250 


30 


1245 



* all units bytes 
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6.0 PROGRAMMING REFERENCE 

6.1 REGISTER ASSIGNMENTS 

The WD10C01A contains 32 output and 23 input 
ports distributed i n a 32 por t address space, 
selected by A0-A4, CS, and RD or WR. 

The ports are split into three functional groups: 



• configuration group 

• device control group 

• ID registers. 

Address lines A4 and A3 select the group, and A2 
through A0 select the register in the group. 



CONFIGURATION 


DEVICE CONTROL 1 


Address 


Assignment 


R/W 


Address 


Assignment 


R/W 


00000 


SRESET 


W 


01000 


PORTX 


R/W 


00001 


SISR 


R/W 


01001 


PORTY 


R/W 


00010 


SIMR 


R/W 


01010 


PORTZ/AMC 


R/W 


00011 


SEQSTS/PYC 


R/W 


01011 


SEQCTL 


R/W 


00100 


CSERR 


R/W 


01100 


START 


R/W 


00101 


CSCTL 


R/W 


01101 


LOOP 


R/W 


00110 


CSVAL 


R/W 


01110 


ECCCTL 


R/W 


00111 


CSCNT 


R/W 


01111 


SECCNT 


R/W 


DEVICE CONTROL 2 


ID REGISTERS 


Address 


Assignment 


R/W 


Address 


Assignment 


R/W 


10000 


ECCP 


W 


11000 


ID0 


R/W 


10001 


ECCS 


R 


11001 


ID1 


R/W 


10010 


SPORT 


R 


11010 


ID2 


R/W 


10011 






11011 


ID3 


R/W 


10100 






11100 


ID4 


R/W 


10101 






11101 


ID5 


R/W 


10110 


TEST - do not use 




11110 


ID6 


R/W 


10111 


SKIP 


W 


11111 


ID7 


R/W 




TABLE 6-1. REGISTER GROUPS 
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6.2 REGISTER DEFINITIONS 

The following sections describe each register in 
detail. The use of the register is described in 
general and/or each bit is described. The table 
below defines how bit directions are defined in 
these sections. Sometimes, a bit encoding is used 
to select a function that is not obvious from the 
definition of the bits involved. Refer to the section 
on Programming Notes for descriptions of these 
special modes. 

The following table contains bit direction defini- 
tions. 



Direction 


Meaning 


R 


indicates that the bit is read only 


W 


indicates that the bit is write only 


R/W 


indicates that the bit may be writ- 
ten and read 


R/C 


indicates that the bit may be read 
and cleared by writing a one to 
that bit 


C 


indicates that the bit may be 
cleared by writing a one to that bit 
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6.3 CONFIGURATION GROUP 

The configuration group is used to do initial set up 
of ports and clocks, handle interrupts, and set up 
the control store memory. 



6.3.1 SRESET - Set Hardware Reset 
Register (00) 

Bits 7-1 are cleared to zero by reset. Bit is set to 
one by an external reset. When writing one to 
SRST, any data on bits 7-1 are lost. 



OSCDIV 


CLKDIV 


osc 


CPUCLK 








XTAL/2 


XTAL/6 





1 


XTAL/2 


XTAL/4 


1 





XTAL 


XTAL/3 


1 


1 


XTAL 


XTAL/2 




REGISTER 


BIT 


DIR 


DEFINITION 


00 


7 


W 


CLKDIV: CPUCLK divisor (see Note 1 below) 


00 


6 


W 


OSCDIV: OSC divisor (see Note 1 below) 


00 


5 


w 


Unused. 


00 


4 


w 


Unused. 


00 


3 


w 


Unused. 


00 


2 


w 


REQTIM: buffer request timing. When this bit is one, REQA 
is set at the same time that the internal buffer data holding 
register is ready. When this bit is zero, REQA occurs one 
RRCLK period early. This aids in interfacing to certain buff- 
er circuits that have a lag in their response times. 


00 


1 


w 


ID3$4: select ID address size (see Note 2) 


00 





w 


SRST: hardware reset. This bit is set by an external reset 
on the RST input, or can be set by writing one to this bit. 
This bit must be set to zero before operating the 
WD10C01 A, or before setting any of the other bits in this 
register or any other register. 



TABLE 6-2. SRESET - SET HARDWARE REGISTER (00) 



NOTE 1 : The CPUCLK dividers are prescaled by 
the OSC dividers, as shown in the table below 
(XTAL is the clock generated by a crystal at X1 
andX2): 

NOTE 2: The eight ID register bytes are split into 
two fields: the first four are address, and auto-in- 
crement for each sector; and the second four are 
flag bytes which do not increment. The ID3$4 bit 
selects whether 3 or 4 bytes of ID address bytes 
will be used in the ID field. In 3 byte address 
fields, register ID0 is ignored. See Table 6-2A. 



Two other considerations: 

• CPUCLK = XTAL/3 will not be a 50% duty 
cycle unless XTAL is also a 50% duty cycle 
clock. 

• When resetting the WD10C01 A under CPU 
control, and the CPU is clocked by CPUCLK or 
OSC, set CPUDIV and OSCDIV back to zero 
before setting SRST. If this is not done, the 
clocks could glitch and cause the CPU to fail. 
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ID3$4 


Address Counter Size 


First Register In Field 





4 bytes 


IDO 


1 


3 bytes 


ID1 (IDO not used) 



TABLE 6-2A. ID REGISTER SELECTION 



6.3.2 SISR - Interrupt Status Register (01 ) 

The Interrupt status register is designed to be 
used in interrupt or polled mode. The status is not 
affected by the interrupt mask register (see 
below). The interrupting condition has precedence 
over the CPU clear, which is performed by writing 



a one to the selected interrupt bit. If the condition 
still exists, the clear will not be successful. The 
COMPLT and FAULT interrupts will stay set until 
the cause of the interrupt goes away. The ID- 
FULL, DXFER, SECEND, and SM$IX interrupts 
are generated by single bit time pulses that are 
triggered by the leading edge of the interrupt 
cause, and can therefore be cleared immediately. 
SEQSTP is a direct status signal and is cleared 
when the sequencer is executing a command. 

Before checking any bit (except SEQSTP), it 
should be cleared by writing a one to it. This 
register is not affected by reset. 



REGISTER 


BIT 


DIR 


DEFINITION 


01 


7 


R 


GINT - group interrupt. This is the state of the INT output, which is 
the logical OR of all of the enabled (by SIMR, see below) interrupt 
sources in this register. 


01 


6 


R/C 


IDFULL - ID registers full. This interrupt is set at the end of any ID 
field access by the transition of the control store ID bit from true to 
false. This interrupt should be serviced before the next ID field is 
accessed. This interrupt can be cleared immediately. 


01 


5 


R/C 


DXFER - data transfer started. This interrupt is set at the start of 
the data field by the transition of the control store BUFF or NOX- 
FER bit from false to true. This interrupt can be used to determine 
when it is safe to write to the LOOP, SKIP, SECCNT, or ID 
registers, if necessary. This interrupt can be cleared immediately. 


01 


4 


R/C 


COMPLT - complete. This interrupt is set in response to the COM- 
PLT input pin going true. This interrupt cannot be cleared until the 
COMPLT input pin goes false. 


01 


3 


R 


SEQSTP - sequencer stopped. This interrupt is set when the se- 
quencer has stopped executing a command. This interrupt is 
cleared when the sequencer starts a new command. 


01 


2 


R/C 


SECEND - sector end interrupt. This interrupt is set by the leading 
edge of the LAST bit in the control store (see below). This is used 
to signal the end of a sector for buffer management and other 
overhead processing. The size of the field in which the LAST bit is 
set can be adjusted to match the processing overhead to the end 
of the sector for maximum CPU performance; the minimum size 
for this field is two bytes. This interrupt can be cleared immediately. 


01 


1 


R/C 


SM$IX - sector mark or index passed. This interrupt is set by the 
leading edge of the SECTOR or INDEX input going true, as 
selected by the mask in the sequencer control register (SEQCTL). 
RRCLK must be present for this interrupt to function. This interrupt 
can be cleared immediately. 



TABLE 6-3. SISR - INTERRUPT STATUS REGISTER 
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REGISTER 


BIT 


DIR 


DEFINITION 


01 





R/C 


FAULT - drive fault. This interrupt is set in response to the DRVFLT 
input pin going true. This interrupt cannot be cleared until the 
DRVFLT input pin goes false. 



TABLE 6-3. SISR - INTERRUPT STATUS REGISTER (CONTINUED) 



6.3.3 SIMR - Interrupt Mask Register (02) 

The interrupts listed are described in the SISR 
description. Writing a one to the mask bit enables 
the interrupt. The state of the mask bits does not 



affect the reading of status in SISR in any way. 
This register is cleared to zero by reset (interrupts 
disabled). Disabling GINT overrides any other 
enables set in this register. 




REGISTER 


BIT 


DIR 


DEFINITION 


02 


7 


R/W 


GINT - enable all interrupts 


02 


6 


R/W 


IDFULL - enable IDFULL interrupt 


02 


5 


R/W 


DXFER - enable DXFER interrupt 


02 


4 


R/W 


COMPLT - enable COMPLT interrupt 


02 


3 


R/W 


SEQSTP - enable SEQSTP interrupt 


02 


2 


R/W 


SECEND - enable SECEND interrupt 


02 


1 


R/W 


SM$IX - enable SM$IX interrupt 


02 





R/W 


FAULT - enable FAULT interrupt 



TABLE 6-4. SIMR - INTERRUPT MASK REGISTER 
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6.3.4 SEQSTS - Sequencer Status (03) 

The following status bits are further clarified in 
later registers and sections. These bits can be 



used to check what sequencer operation is taking 
place. 



REGISTER 


BIT 


DIR 


DEFINITION 


03 


7 


R 


DATFLD - data field active. This bit means that the either 
the BUFF or the NOXFER bit is now active from the control 
store. 


03 


6 


R 


ECCEN - checksum calculation active. The WD10C01 A is 
now calculating the checksum. This status line usually en- 
compasses the ID or data field and checksum bytes, and is 
active during both read and write. 


03 


5 


R 


LAST - The LAST bit is now active from the control store. 


03 


4 


R 


ID - The ID bit is now active from the control store. 


03 


3 


R 


CHK - The CHK bit is now active from the control store. 
The WD10C01 is now processing the checkbytes or 
syndromes for the CRC or ECC. 


03 


2 


R 


WAIT - The wait sequencer is waiting for an event such as 
index, sector mark, address mark, or byte sync. 


03 


1 


R 


AMDET - Address mark detect. This is the raw AMDET pin 
input. This pin can be used as an extra input bit in designs 
(such as ST506) that do not require this function. 


03 





R 


SEQOUT - The SEQOUT bit is now active from the control 
store. 



TABLE 6-5. SEQSTS - SEQUENCER STATUS REGISTER 
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6.3.5 PYC - PORT Y Configuration (03) 

This port is used to configure each port Y bit for 
input or output. This register is cleared to zero by 



reset, which causes all port Y pins to become 
inputs. 



REGISTER 


BIT 


DIR 


DEFINITION 


03 


3 


W 


PY3DIR - bit 3 direction: = in; 1 = out 


03 


2 


W 


PY2DIR - bit 2 direction: = in; 1 = out 


03 


1 


w 


PY1 DIR - bit 1 direction: = in; 1 = out 


03 





w 


PY0DIR - bit direction: = in; 1 = out 




TABLE 6-6. PYC - PORT Y CONFIGURATION (03) 
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6.3.6 Control Store Windows 

The heart of the WD10C01A is its control store 
memory, which is organized as 32 instruction 
words of 28 bits each. Each 28 bit instruction is 
divided into three 8 bit parts: the control byte, the 
value byte, and the count byte; and one 4 bit part: 
the error control byte. The window registers are 
used to access these bytes. The control store ad- 
dress is specified by writing to the START 
register. Any write to a control store window 
register causes the START register to automat- 
ically increment to the next address to facilitate 
loading. 



The contents of the control store are not affected 
by reset. 



6.3.6.1 CSERR - Control Store Error Control 
Byte Window (04) 

The transition of DAC from false to true, together 
with WG (in the control byte of the control store) 
or RCMP (read compare enable in the SEQCTL 
register), causes a one byte prefetch from the 
buffer. If an immediate fill character is used to 
specify the format data field or read compare byte 
(see below), and DAC is used to select the ECC 
for the data field, prefetch REQA signals are 
generated anyway. 



REGISTER 


BIT 


DIR 


DEFINITION 


04 


3 


R/W 


FAIL - Enable error failure. Setting this bit to one causes a 
command stop if an error is detected while executing the 
current control store instruction. The error can be 
CRC/ECC error, data miscompare error or a parity error 
during write operation. 


04 


2 


R/W 


RTY - Enable read error retry. This bit is valid only during 
read. Setting this bit to one causes a sector retry (see 
below) if a read error is detected while executing the cur- 
rent control store instruction. An example of the use of this 
bit is to cause a retry on an ID field miscompare. 


04 


1 


R/W 


DAC - Data field active. Set this bit to one when the current 
control store instruction involves a data field operation. 
This signal is used to select the data field checksum (RS- 
ECC) and to control data prefetch. When this bit is zero an 
ID field operation is assumed, and the ID field checksum 
(CRC) is selected. 


04 





R/W 


SEQOUT - user defined output. This is tied to the 
SEQOUT output pin through some delays which align the 
signal to the byte boundary of the read or write serial data. 
This output can be used to control an external ECC circuit, 
such as a Reed-Solomon code circuit. 



TABLE 6-7. CSERR-CONTROL STORE ERROR CONTROL BYTE WINDOW 
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6.3.6.2 CSCTL - Control Store Control Byte 
Window (05) 



REGISTER 


BIT 


DIR 


DEFINITION 


05 


7 


R/W 


SVSEL - value byte select. This bit selects the use of the 
value byte, which can be either immediate data (SVSEL = 
0) or a select for data source or destination (SVSEL = 1 ). 


05 


6 


R/W 


CWSEL - count byte select. The bit selects the use of the 
count byte, which can be either an immediate byte count 
(CWSEL = 0) or to specify an external condition to wait for 
(CWSEL =1). 


05 


5 


R/W 


WG - write gate output. This is tied directly to the WG out- 
put pin. 


05 


4 


R/W 


RG - read gate output. This is tied to the retry logic, which 
is then tied to the RG output pin. 


05 


3 


R/W 


AM - address mark enable output. This is tied to the AMC 
register (see below) which generates the AMENA signal. 


05 


2 


R/W 


CMPEN - compare enable. This signal is used to indicate 
that the bytes of the currently selected data source are to 
be compared with incoming serial data (ID, marker bytes, 
buffer data). 


05 


1 


R/W 


SKPEN - jump to SKIP address at end of the current in- 
struction. This causes an absolute jump to the SKIP 
register address when the current control store instruction 
is finished. Typically, this is used to set up a read and write 
program in the control store with a common ID search 
routine. (See later examples and SKIP register definition.) 


05 





R/W 


JMPEN - jump to LOOP address at end of the current in- 
struction. This causes a conditional jump to the LOOP 
register if the sector count (SECCNT) is not zero. If SEC- 
CNT is zero, the next sequential instruction is executed. 
Typically, this is used to specify the end of a sector, and 
tells the sequencer to go to the LOOP register address to 
operate on the next sector. 




TABLE 6-8. CSCTL - CONTROL STORE BYTE WINDOW (05) 
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6.3.6.3 CSVAL - Control Store Value Byte 
Window (06) 

The use of the value byte depends on the state of 
the SVSEL bit of the control byte. When SVSEL is 
zero, the value byte specifies actual immediate 
data, like address mark, gap, and PLL sync bytes. 
When SVSEL is one, the value byte becomes an 
encoded bit field that enables the correct data 
source or destination. Both uses are shown 
below. 



To get large sector sizes, multiple control store 
instructions are used. For example, for a 1024 
byte sector size, use four instructions with 256 
byte count fields. With this scheme, the last in- 
struction must be flagged for error correction and 
write prefetch purposes. The LAST bit must be set 
with the BUFF or NOXFER bit to ensure proper 
operation. 



REGISTER 


BIT 


DIR 


DEFINITION 


06 


7-0 


R/W 


VALUE7-0 (actual value for field) 



TABLE 6-9. SVSEL of CONTROL BYTE ZERO 
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REGISTER 


BIT 


DIR 


DEFINITION 


06 


7 


R/W 


BUFF - data buffer. This bit causes data to be transferred 
to (disk read) or from (disk write or read compare) the disk 
data buffer. The leading edge of BUFF causes a decre- 
ment of the SECCNT register, and increments the ID write 
register counters (see below). 


06 


6 


R/W 


NOXFER - no data transfer. This bit is used when an 
ECC/CRC verify on the data field with no buffer data trans- 
fer is being performed. This bit is set INSTEAD of the 
BUFF bit, and affects the SECCNT and ID registers in the 
same way as the BUFF bit. 


06 


5 


R/W 


LAST - last data buffer xfer control store instruction. Long 
data fields (greater than 256 bytes) are specified by using 
multiple control store instructions (2 for 512 bytes, 4 for 
1024 bytes, etc.). When the control store instruction is the 
last instruction of the data field specifiers, the LAST bit 
must be set to flag this. This only applies to data buffer 
transfers. LAST is set in ADDITION to BUFF or NOXFER. 
The CSCNT byte must be set to at least 01 when this bit is 
used. 


06 


4 


R/W 


R/W ID - ID registers. On ID read, the incoming ID field 
from the disk is compared against the ID write registers 
and written at the same time to the ID read registers. On 
write (format), the data source is the ID write registers. 


06 


3 


R/W 


CHK - checksum field. On read, this starts the check for a 
correct checksum. On write, this causes the checksum 
shift register to be gated into the NRZ0 data. In either 
case, the calculation is halted at the end of this instruction. 
The DAC bit in CSERR window selects the appropriate 
checksum automatically. 




TABLE 6-10. SVEL of CONTROL BYTE ONE 
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6.3.6.4 CSCNT - Control Store Count Byte 
Window (07) 

The use of the count byte depends on the state of 
the CWSEL bit of the control byte. When CWSEL 
Is zero, the count byte specifies the actual length 
of that field in bytes. When CWSEL is one, the 
count byte becomes an encoded bit field that 



specifies a condition to wait for before proceding. 
Both uses are shown below. 

The count value is set to the actual number of 
bytes to do minus one. Therefore, 00 denotes a 
one byte field, and FF a 256 byte field. 



REGISTER 


BIT 


DIR 


DEFINITION 


07 


7-0 


R/W 


COUNT7-0 (actual size of field - 1 ) 



TABLE 6-11. CWSEL of CONTROL BYTE ZERO 



REGISTER 


BIT 


DIR 


DEFINITION 


07 


7 


R/W 


WDAM - Wait for data address mark (ST412 ONLY). This 
bit causes the WD1 0C01 A to pause until a data address 
mark is detected at the AMDET input. Bits 6-0 specify a 
timeout count that is the maximum number of byte times 
from the end of the ID field to the data address mark. The 
value field is used to specify the data pattern to compare 
against for byte sync. 


07 


6 


R/W 


WIAM - Wait for ID address mark (ST412 ONLY). This bit 
causes the WD10C01 A to pause until an ID address mark 
is detected at the AMDET input. The value field is used to 
specify the data pattern to compare against for byte sync. 


07 


5 


R/W 


WIX - Wait for index. Pauses until index is detected at the 
INDEX input. 


07 


4 


R/W 


WSM - Wait for sector mark. Pauses until sector mark is 
detected at the SECTOR input. 


07 





R/W 


STOP - Stop immediate. This bit causes the command se- 
quencer to immediately turn off all control outputs and 
return to the stopped state. 



TABLE 6-12. CWSEL of CONTROL BYTE ONE 
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6.3.6.5 Wait Condition Sequences 

The following sequences are performed on the 
above wait conditions to ensure proper error han- 
dling: 



WIAM: 



WDAM: 



Wait for AMDET. If the byte count is ex- 
ceeded, a sync error is recorded, and (if 
the control store FAIL bit is set) the com- 
mand halts. When AMDET is detected 
correctly, the sequencer waits sixteen bit 
times for the sync byte in the value byte to 
be matched. The bit counter is decre- 
mented on each bit while the AMDET sig- 
nal is active. If this bit count is exceeded, 
this is also a sync error. When a sync 
error occurs, the sequencer will stop or 
retry as defined by the control store FAIL 
and RTY bits. Checksum calculation starts 
when the sync byte is detected, and the 
sync byte is included in the calculation. 



Wait for AMDET. Since ID address marks 
could be found anywhere, there is no byte 
count, and the CPU must perform its own 
timeout. However, after AMDET is 
detected, the sequencer waits sixteen bit 
times for the sync byte in the value byte to 
be matched. The bit counter is decre- 
mented on each bit while the AMDET sig- 
nal is active. If this bit count is exceeded, 
this is considered a sync error, and (if the 
control store RTY bit is set) a retry is per- 
formed (ID retry is discussed in a later 
section). Checksum calculation starts 
when the sync byte is detected, and the 
sync byte is included in the calculation. 




WIX and WSM: 



The signal (index or sector mark) is waited 
on forever. The CPU must perform its own 
timeout and issue the KILL bit to the 
SEQCTL register to stop the command 
(see below). To do a wait for either index 
or sector mark (typical on hard sector 
drives), set both WIX and WSM. 
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6.4 DEVICE CONTROL GROUP 

The device control group Is used to set and read 
port X, Y, and Z bits for drive control. It is also 
used to execute data transfer commands with the 
sequencer, and correct ECC errors. 



6.4.1 PORTX - PORTX Output Bits (08) 

This register is cleared to zero by reset. The state 
of the output bits may be read back, allowing for 
read/modify/write operation. 



REGISTER 


BIT 


DIR 


DEFINITION 


08 


7-0 


R/W 


PX7-0 (direct to output pins) 



TABLE 6-13. PORTX OUTPUT BITS (08) 



6.4.2 PORTY - PORT Y I/O Bits (09) 

The direction of each bit is controlled by the Port 
Y Control Register (03). If a particular bit is set for 
input, then the state of the external pin is read by 
a read of this port. If the bit is set for output, then 
the last state written to that bit is read (same as 
Port X). Writing to this register does not affect bits 
configured for input. Reset sets all bits to input, 
but does not affect the output latched data. 



REGISTER 


BIT 


DIR 


DEFINITION 


09 


3-0 


R/W 


PY3-0 (direct to I/O pins) 



TABLE 6-14. PORTY I/O BITS (09) 



6.4.3 PORTZ- PORT Z INPUT BITS (0A) 



REGISTER 


BIT 


DIR 


DEFINITION 


0A 


5-0 


R 


PZ5-0 (direct from input pins) 



TABLE 6-15. PORTZ INPUT BITS (0A) 
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6.4.4 AMC - Address Mark Control (OA) 

The AMC register defines during which bit times 
the AMENA signal is active. When AM is set in the 
control store control byte of the current instruction, 
the AMENA signal will be active during the bit 
times specified in this register. This register is not 
affected by reset. Note that the bits in this register 



are ordered backwards from the data bus num- 
bering; i.e., writing 01 to this register will turn on 
AMENA when bit 7 of the serial data stream is 
active on NRZO. 



REGISTER 


BIT 


DIR 


DEFINITION 


OA 


7-0 


W 


Address mark bit control bit 0-7 




TABLE 6-16. AMC - ADDRESS MARK CONTROL (OA) 
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6.4.5 SEQCTL - Sequencer Control Register 
(OB) 



REGISTER 


BIT 


DIR 


DEFINITION 


OB 


7 


W 


RGERLY - read gate early bit. This bit controls the timing 
of RG signal. If the bit is set to zero, the RG signal is ex- 
tended automatically until the ECC/CRC calculation is 
finished. Setting this bit to one will disable this feature. 


OB 


3 


W 


IXMASK - index interrupt mask. This bit is used with the 
SMMASK bit to select the conditions for the SM$IX inter- 
rupt (see table below). 


OB 


2 


w 


SMMASK - sector mark interrupt mask (see table below). 


OB 


1 


w 


RCMP - enable read compare. This bit MUST be set when 
performing a read data compare command with the data 
buffer. It is used to change the buffer access from write buff- 
er to read buffer. 


OB 





w 


KILL - immediately kill the currently executing command. 
The sequencer will stop within three byte times. This bit 
must be asserted for at least 2 bytes time. 


OB 


5 


R 


ECCERR - checksum error. An ECC or CRC error has 
been detected. This bit is valid when the sequencer is 
stopped. If the control bit IGNERR in ECCCTL is turned on, 
this status bit will always be zero and the sequencer will 
continue its operation ignoring the error condition. 


OB 


4 


R 


IDERR - ID checksum error. A CRC ID field error occurred 
during the previous ID field read. This condition is latched 
when a checksum error causes an ID retry, and is cleared 
at the start of the next ID field read (ID false to true transi- 
tion). 


OB 


3 


R 


PTYERR - parity error. A parity error during a transfer from 
the data buffer to the WD10C01A occurred during the pre- 
vious command. If FAIL bit is set in the current CS instruc- 
tion, the sequencer will stop its operation at the end of cur- 
rent instruction and WG output will be deasserted. This bit 
is valid only after the sequencer is stopped. 


OB 


2 


R 


SYNCER - sync search error. The search for a data field 
marker byte or sync byte failed. This bit is valid when the 
sequencer is stopped. 


OB 


1 


R 


CMPERR - compare data error. Afield that was compared 
against some specified data source compared incorrectly. 
This bit is valid when the sequencer is stopped. 



TABLE 6-17. SEQCTL - SEQUENCER CONTROL REGISTER (OB) 
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This register Is not affected by reset. The IXMASK 
and SMMASK select the conditions for the SM$IX 
interrupt. Note that these mask bits are used to 
select only the source, and do not affect or enable 
the external interrupt signal. The table below 
defines the use of the SM$IX source mask bits: 



SMMASK 


IXMASK 


SM$IX set true on 
leading edge of: 








nothing 





1 


INDEX 


1 





SECTOR 


1 


1 


INDEX OR SECTOR 



6.4.6 START - Sequencer Start Address (OC) 

The START register is not affected by reset. This 
register is actually two devices: the START hold- 
ing register, and the control store address counter. 
When the CPU writes to this port, the data bus 
value is latched into both the holding register and 
the address counter. The holding register is af- 
fected only by CPU writes, but the counter is in- 
cremented or reloaded by several different 
events. The START register is used for the follow- 
ing functions: 

1 . The START register specifies the starting 
address in the control store for the pro- 
gram loaded there. When the CPU writes 
to the SECCNT register (see below), and 
the sequencer is stopped, the sequencer 
loads the contents of the holding register 
into the address counter and starts with 
the instruction at that location. 

2. Reading this port gives the current con- 
tents of the control store address counter. 
Reading the counter while the sequencer 
is running indicates which control store in- 
struction is currently being executed. It is 
recommended that the CPU 'debounce' 
this port by reading the START register 
until the same value is read twice. This 
prevents erroneous values being read at 



transition times. Reading the counter 
when the sequencer is stopped indicates 
where in the control store the condition 
causing the last halt occurred. This can be 
used to determine in which instruction an 
ECC or other fatal error occurred. 

3. The START register is used to specify the 
current address for control store window 
access. See control store windows above. 
The control store address counter is auto- 
matically incremented after any write to a 
control store window register (CSERR, 
CSCTL, CSVAL, or CSCNT). 

4. Writing to the START register clears error 
conditions. When a read error occurs, 
causing the command to halt (see FAIL bit 
in CSERR above), the error status is 
latched in the SEQCTL register. A write to 
the START register clears ECCERR, I0E- 
I4E, CERR, EERR, SYNCER, CMPERR, 
and also PTYERR (which does not cause 
a halt). This must be performed prior to 
issuing any new commands. If SECCNT is 
non-zero, the sequencer will start as soon 
as the error is cleared. 

While the sequencer is running, the control store 
address counter is the program counter, and 
points at the current instruction being executed. 
The address in the counter can be changed by 
the following events during program execution: 

1 . At the end of an instruction that has the 
SKPEN bit set, the address counter is 
loaded with the contents of the SKIP 
register. 

2. At the end of an instruction that has the 
JMPEN bit set, if the SECCNT register is 
not zero (i.e., more sectors to do), the ad- 
dress counter is loaded with the contents 
of the LOOP register. If SECCNT is zero, 
the address counter is incremented and 
the next sequential instruction is executed. 




REGISTER 


BIT 


DIR 


DEFINITION 


OC 


4-0 


R/W 


START4-0 



TABLE 6-18. START- SEQUENCER START ADDRESS (OC) 
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3. If an instruction has the RTY bit set, and 
an error flag is currently set (ECCERR, 
CMPERR, or SYNCER), a retry occurs 
and the address counter is loaded with the 
contents of the LOOP register. 

4. If a program halts due the STOP bit being 
set (i.e., the normal end of the program 
with SECCNT zero), and the CPU writes 
to the SECCNT register with more blocks 
to do before it detects the stopped condi- 
tion, the sequencer will restart using the 
current value of the START holding 
register. This prevents erroneous restarts 
from occurring. 

5. In all other cases, the control store address 
counter is incremented and the next se- 
quential instruction is executed. 



6.4.7 LOOP - Sequencer Loop Address (OD) 

The LOOP register specifies the address to set 
the START value to at the end of a control store 
instruction that has the JMPEN bit set in the con- 
trol byte. This also happens when an ID retry oc- 
curs (see below). The use of the LOOP register is 
based on the idea that all sector operations are 
sequential in nature, and that when the operation 
is complete, a single jump back to the start of the 
sequential sector operation is all that is needed. 
This register is not affected by reset. 



REGISTER 


BIT 


DIR 


DEFINITION 


OD 


4-0 


W 


LOOP4-0 (address to loop to in loop) 



TABLE 6-19. LOOP - SEQUENCER LOOP ADDRESS (OD) 
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6.4.8 ECCCTL - Error Correction Control 
Register (OE) 

CRCSET and ECCCLR must be set high and 
then low to complete the preset or clear operation. 
All bits in this register are cleared to zero upon 
reset time. 



REGISTER 


BIT 


DIR 


DEFINITION 


OE 


5 


W 


ECCCLR - clear CRC and ECC shift register. Writing one 
to this register causes the CRC and ECC shift register to 
be held in the clear (all bits zero) state. The CPU must then 
write zero to this bit to complete the clear pulse. 


OE 


4 


W 


CRCSET - preset CRC shift register. Writing one to this 
register causes the CRC shift register to be held in the 
preset (all bits one) state. The CPU must then write zero to 
this bit to complete the preset pulse. 


OE 


3 


w 


CRCNIT - CRC shift register initial state. This bit selects 
whether to start the CRC shift register with all zeros 
(CRCNIT = 0) or all ones (CRCNIT = 1 ) when starting 
checksum calculation. 


OE 


2 


w 


IGNERR - ignore CRC/ECC error. Forces ECCERR bit in 
the SEQCTL register to zero, and causes the read error 
logic to ignore this error by continuing with its operation. 
The status bit EERR/CERR in the ECCS register is not af- 
fected by this control bit and will be set on error. 


OE 


1 


w 


DISPTY: disable parity checking. Setting this bit to one for- 
ces the PTYERR bit in the SEQCTL register to zero. Even 
if the FAIL bit in the current CS instruction is set, the se- 
quencer will continue its operation normally on parity error. 




TABLE 6-20. ECCCTL - ERROR CORRECTION REGISTER (OE) 



11/19/91 



20-27 



WD10C01A 



PROGRAMMING REFERENCE 



6.4.9 SECCNT - Sector Count Register (OF) 

The sector count register is used to specify the 
number of iterations to perform the operation 
programmed into the control store. Writing any 
non-zero value to the SECCNT register causes 
the sequencer to start, so therefore the range of 
possible sector counts is from 1 to 255. Writing a 
zero to SECCNT during the data field will cause 
the sequencer to halt at the end of the current 
sector. The sector count is automatically decre- 



mented at the start of the data field, after the byte 
sync or address mark character(s) have been 
detected (leading edge of BUFF or NOXFER). 
The SECCNT register can be written to at any 
time except the start of the data field. 

This register is cleared to zero by reset, or when 
the KILL bit in the SEQCTL register is set. It is 
NOT cleared by a halt on error, so that the sector 
in error can be determined. 



REGISTER 


BIT 


DIR 


DEFINITION 


OF 


7-0 


R/W 


Sector count value 



TABLE 6-21. SECCNT - SECTOR COUNT REGISTER (OF) 
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6.4.10 ECCP- ECC Parameter Register (10) 



REGISTER 


BIT 


DIR 


DEFINITION 


10 


3 


W 


SYNCECC - Include sync byte in the ECC calculation. This 
bit is initialized to one upon reset. If this control bit is set to 
one, the ECC calculation begins with the first data sync 
byte. Otherwise, the first data sync byte is excluded from 
the ECC calculation. 


10 


2 


W 


WSYNCCRC - include sync byte in the CRC calculation. 
This bit is initialized to one upon reset. If this control bit is 
set to one, the CRC calculation begins with the first ID sync 
byte. Otherwise, the first data sync byte is excluded from 
the CRC calculation. 


10 


1 


w 


DEG6/5 - RS ECC degree control bit. This bit is initialized 
to zero upon reset. If this bit is set to zero, degree 5 polyno- 
mial is selected, otherwise degree 6 will be used. 


10 





w 


WIFS5/3 - Interleave select. This bit is initialized to zero 
upon reset. Setting this bit to one will select five way inter- 
leave format, otherwise three way format will be used. 




TABLE 6-22. ECCP - ECC PARAMETER REGISTER (10) 
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6.4.11 ECCS - RS-ECC Status Register (11) 



REGISTER 


BIT 


DIR 


DEFINITION 


11 


6 


R 


EERR - ECC error detected. This bit is set whenever an 
ECC error is detected in any one of the interleaves. At least 
one of the status bits I4E - I0E will also be set. This bit is 
cleared to zero after reset and before another operation is 
started. This bit is not affected by the control bit IGNERR, 
which prevent the status ECCERR from being set. 


11 


5 


R 


CERR - CRC error detected. This status bit is set whenever 
a CRC error is detected in the ID field. This bit is cleared 
upon reset. The control bit IGNERR does not affect this 
status bit. 


11 


4 


R/W 


I4E - ECC error in interleave 4. This bit is set only when an 
ECC error is detected in the interleave 4. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


11 


3 


R/W 


I3E - ECC error in interleave 3. This bit is set only when an 
ECC error is detected in the interleave 3. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


11 


2 


R/W 


I2E - ECC error in interleave 2. This bit is set only when an 
ECC error is detected in the interleave 2. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


11 


1 


R/W 


11 E - ECC error in interleave 1 . This bit is set only when an 
ECC error is detected in the interleave 1 . The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 


11 





R/W 


I0E - ECC error in interleave 0. This bit is set only when an 
ECC error is detected in the interleave 0. The microproces- 
sor can read the syndrome bytes from this interleave only 
when this status bit is set. This status bit is cleared upon 
reset. It also be cleared by writing a zero into this bit. 



TABLE 6-23. ECCS - RS-ECC STATUS REGISTER (11) 
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6.4.12 SPORT - Syndrome Port (12) 

The microprocessor reads the syndrome bytes for 
each interleave through this port. The WD10C01A 
automatically transfers the syndromes of the next 
interleave in error after all the syndromes in the 
current interleave are read. The microprocessor 
must read (interleave number * ECC degree) 
times from this port to complete a syndrome 
transfer from an interleave. The syndrome bytes 
are transferred starting with the highest byte from 
the lowest interleave number. Only the 
syndromes from an interleave in error are trans- 
ferred. If the microprocessor clears the error flag 
from an interleave, the syndromes from that inter- 
leave cannot be read, but the content of the 
syndrome registers areTiot destroyed. Those can 
be read by reseting the error flag to one. 

The syndrome bytes are valid only when sequen- 
cer is stopped. The syndrome registers are 
cleared upon reset. 



6.4.13 TEST - Test Register (16) 

This register is intended for test purpose in the 
manufacturing and must not be used in normal 
operations. It is described here only for reference. 

There are three test functions implemented in this 
register. First, writing into this register with any 
data, will set the OSC and CPUCLK outputs in a 
predetermined state. During the write cycle, the 
OSC output is set to level and the CPUCLK 
output is set to a 1 level. 

Second, the microprocessor can write 080H into 
this register to disable the output signal WG. This 
signal will remain inactive until the microprocessor 
writes a 00H into the register. 

Third, the microprocessor can write OCOH into the 
register to increment the ID registers. Sub- 
sequently, the microprocessor must write 00H, 
before it can continue to increment the registers 
again. The output WG is also disabled during the 
test operation. 




REGISTER 


BIT 


DIR 


DEFINITION 


12 


7-0 


R 


SYNDR7-0 - Syndrome bit7-bit0. 



TABLE 6-24. SPORT - SYNDROME PORT (12) 
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6.4.14 SKIP - Skip Address Register (17) 

This register is not affected by reset. The SKIP 
register is used to perform an absolute jump to 
the location specified at the completion of a con- 
trol store instruction that has the SKPEN bit set to 
one. This can typically be used to define whether 
the current operation is to be a sector read or a 
sector update write. Consider the following 
generalized control store program that has three 
parts: ID search, read data field, and write data 
field. 



When the SKIP register is set to address 05, the 
WD10C01A will perform a sector read operation. 
When the SKIP register is set to address 0C, the 
WD10C01A will perform a sector write operation. 
A more detailed example can be found in a sub- 
sequent section of this document. 



REGISTER 


BIT 


DIR 


DEFINITION 


17 


4-0 


W 


SKIP4-0 



TABLE 6-25. SKIP - SKIP ADDRESS REGISTER (17) 



ADDRESS 


CONTROL STORE 
OPERATION 


00 


ID SEARCH 


01 


ID SEARCH 


02 


ID SEARCH 


03 


ID SEARCH 


04 


ID SEARCH (SKPEN bit set) 


05 


READ DATA FIELD 


06 


READ DATA FIELD 


07 


READ DATA FIELD 


08 


READ DATA FIELD 


09 


READ DATA FIELD 


0A 


READ DATA FIELD 


0B 


STOP 


OC 


WRITE DATA FIELD 


0D 


WRITE DATA FIELD 


0E 


WRITE DATA FIELD 


OF 


WRITE DATA FIELD 


10 


WRITE DATA FIELD 


11 


WRITE DATA FIELD 


12 


STOP 



TABLE 6-26. SKIP CONTROL STORE 
EXAMPLE 
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6.5 ID REGISTER GROUP 

The eight ID registers (IDO - ID7) are used to set 
the ID field during format and read/write opera- 
tions. Writing to the ID registers sets the field to 
search for, or to write during format. These 
registers are refered to as the ID write registers. 
The first four ID write registers are set up as a 
32-bit counter, and they automatically increment 



at the start of the data field. The second four are 
simple registers and are intended for use as flag 
and defect indicators. 

The ID read registers contain the last ID field read 
from the media (valid when IDFULL in SISR is 
true). These registers must be read when the se- 
quencer is NOT reading an ID field, or else the 
CPU will not read the correct value. 




REGISTER 


BIT 


DIR 


DEFINITION 


18 


7-0 


R/W 


IDO bits 7-0 (counter MSbyte) 



TABLE 6-27. IDO - ID REGISTER (18) 



REGISTER 


BIT 


DIR 


DEFINITION 


19 


7-0 


R/W 


ID1 bits 7-0 (counter) 



TABLE 6-28. ID1 - ID REGISTER 1 (19) 



REGISTER 


BIT 


DIR 


DEFINITION 


1A 


7-0 


R/W 


ID2 bits 7-0 (counter) 



TABLE 6-29. ID2 - ID REGISTER 2 (1 A) 



REGISTER 


BIT 


DIR 


DEFINITION 


1B 


7-0 


R/W 


ID3 bits 7-0 (counter LSbyte) 



TABLE 6-30. ID3 - ID REGISTER 3 (1B) 
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REGISTER 


BIT 


DIR 


DEFINITION 


1C 


7-0 


R/W 


ID4 bits 7-0 (flag) 



TABLE 6-31. ID4 - ID REGISTER 4 (1C) 



REGISTER 


BIT 


DIR 


DEFINITION 


1D 


■7-0 


R/W 


I D5 bits 7-0 (flag) 



TABLE 6-32. ID5 - ID REGISTER 5 (1D) 



REGISTER 


BIT 


DIR 


DEFINITION 


1E 


7-0 


R/W 


"I D6 bits 7-0 (flag) 



TABLE 6-33. ID6 - ID REGISTER 6 (1E) 



REGISTER 


BIT 


DIR 


DEFINITION 


1E 


7-0 


R/W 


ID7 bits 7-0 (flag) 



TABLE 6-34. ID7 - ID REGISTER 7 (1F) 
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6.6 DEVICE PROGRAMMING 



6.6.1 Initialization 

1 . Write one and then zero to the SRST bit of 
the SRESET register to complete the 
device reset sequence. 

2. Write the remainder of the bits of the 
SRESET register to the CPU and OSC 
clock speeds, and ID counter size and 
data request timing. 

3. Clear all interrupts that can be cleared by 
writing OFFH to the SISR (some may still 
be set because they are level true). Write 
the initial mask to the SIMR. 

4. Configure port Y 

5. Configure the address mark control bits 
using the AMC register. 

6. Set up the ECC by programming the EC- 
CCTL and ECCP registers. Set CRCNIT in 
the ECCCTL register to the appropriate 
value for a zero seed or a one's seed. 

7. Load the control store program into the 
control store. 



6.6.2 Command Programming 

1. Load the control store with the particular 
instructions appropriate for the command 
desired (format, read, write, etc.), if neces- 
sary. 

2. Set the START, LOOP, and SKIP registers 
to the appropriate values for the control 
store program. 

3. Write the number of sectors to do to SEC- 
CNT. This also starts the command se- 
quencer. 

4. Clear the interrupt status bits, and set the 
mask. 

5. Wait for SEQSTP. Check the SEQCTL and 
ECCS status bits for an error. 



6.6.3 Control Store Programming 

There are a few 'tricks' in programming the 
WD10C01A control store that are not indicated by 
the discussions of the individual control bits: 

READ BYTE SYNC 

On formats that use a simple byte sync byte (like 
ESDI) for ID and data field markers, the search is 
performed by setting the control byte bits RG and 
CMPEN, and the count field is set with a maxi- 
mum byte timeout count. The condition of no byte 
sync yet found, and RG * CMPEN set, defines 
this mode. AMDET is not used and has no effect 
on this operation. Checksum calculation starts 
when the sync byte is detected, and the sync byte 
is included in the calculation. 

WRITE BYTE SYNC 

Write byte sync is used to mark the start of the 
byte string for which the ECC/CRC checksum is 
calculated. To do this, set WG and CMPEN in the 
control byte. The start of the control store instruc- 
tion with WG and CMPEN set clears the check- 
sum register to the state defined by CRCNIT. The 
transition to the next instruction begins the check- 
sum calculation. For example, in a ST412 drive 
the ID field might be defined by the byte string: A1 
FE ID ID ID FLAG ECC ECC ECC ECC; with PLL 
sync before, and gap after. The control store in- 
structions would be coded as follows. 
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ADDRESS 


DATA 


COUNT 


CONTROL 


ERROR 


00 


00 


OB 


WG,CMPEN 


PLL sync field 


01 


A1 


00 


WG,AM 


address mark 


02 


FE 


00 


WG 


address marker 


03 


ID 


02 


WG,SVSEL 


ID field 


04 


ID 


00 


WG,SVSEL 


flag byte 


05 


CHK 


03 


WG,SVSEL 


checksum 


06 


00 


03 


WG 


pad and splice 



TABLE 6-35. WRITE BYTE SYNC EXAMPLE 



In the example, control store instruction 00 con- 
tains the WG-CMPEN combination that says to 
begin checksum calculation on instruction 01; 
therefore, the bytes defined in instructions 01 
through 05 are included in the checksum calcula- 
tion. The calculation is terminated by the CHK 
value code in instruction 05. 

DATA FIELD SIZES 

The data field size is set by using multiple control 
store instructions to build up the size in 256 (or 
less) increments. Two issues come up with this 
method: 

1) The last data field instruction must be 
marked to ensure correct buffer data 
transfer timing and checksum calculation. 
The LAST bit is used with the BUFF or 
NOXFER bit to perform this marking. 

2) For programming purposes, it is desirable 
to not have to change the control store 
significantly when changing sector size. To 
do this, allocate enough control store in- 
structions to be able to set the largest sec- 
tor size to be supported. Then, adjust the 
count fields in all of the instructions to get 
the desired sector size. For example, if a 
controller supports 256, 512, and 1024 
byte sectors, use the programming shown 
in the example below: 



Rel Addr 


Counts for 


256 


512 


1024 


00 


3F 


7F 


FF 


01 


3F 


7F 


FF 


02 


3F 


7F 


FF 


03 


3F 


7F 


FF 



TABLE 6-36. DATA FIELD SIZE EXAMPLE 

If the LAST bit is being used as an interrupt, the 
last instruction can be split into two parts. The 
second part contains the LAST bit, and can be 
adjusted to the required time before the end of the 
sector, since the leading edge of LAST generates 
the interrupt. 

ID SEARCH AND FLAG BYTES 

When specifying an ID field, it is desirable to have 
address bytes that are compared on a search, 
and flag bytes that are not. To do this, split the ID 
field in the control store into two separate instruc- 
tions for address and flag. When performing an ID 
search, set the CMPEN bit only in the ID address 
instruction, and not in the ID flag instruction. 

DATA CHECKSUM VERIFY 

To do a data field ECC or CRC verify only com- 
mand, set the data field source as NOXFER. No 
data will be transferred to the buffer. 
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DATA COMPARE VERIFY 

To do a data field compare verify, set the RCMP 
bit in the SEQCTL register, and set the CMPEN 
bit in the data field control store instruction. Data 
will be transferred from the data buffer and com- 
pared with the incoming disk data. 

FILL GAP TO END OF TRACK 

To generate fill data through to the end of the 
track during format, set the WIX bit in the last 
control store instruction, and set WG and the fill 
character. The WD10C01A will fill in gap bytes 
until index occurs. This also works for gaps to 
sector marks. 



6.6.4 Programming Examples 

This section gives programming examples for 
ST412 format, read, and write commands. The 
following design parameters are assumed: 

1 . The ID field is three bytes of address, one 
byte of flag, and two bytes of CRC. 

2. Intersector gaps are 20 bytes of 04EH 
data, PLL sync fields are 12 bytes of 
000H. 

3. ID address mark and marker byte are 
0A1FEH, data address mark and marker 
byte are 0A1F8H. 

4. Data field is protected through degree six 
ECC with interleave factor of five. There 
are 30 bytes of checksum. 

The WD10C01A registers are programmed as fol- 
lows: 

SRESET: ID3$4 = 1 (3 bytes of address counter) 
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6.6.4.1 Format Track Example 


ADDRESS 


VALUE 


COUNT 


CONTROL 


NOTES 


00 


00 


WIX 


CWSEL 


start on index 


01 


4E 


13 


WG 


post index gap 


02 


00 


OB 


WG, CMPEN 


PLLsync 


03 


A1 


00 


WG,AM 


address mark 


04 


FE 


00 


WG 


address mark 


05 


ID 


03 


WG,SVSEL 


ID address & flag 


06 


CHK 


01 


WG,SVSEL 


CRC 


07 


00 


02 


WG 


write splice 


08 


00 


OB 


WG, CMPEN 


data PLLsync 


09 


A1 


00 


WG, AM, DAC 


address mark 


0A 


F8 


00 


WG, DAC 


address mark 


OB 


BUFF 


7F 


WG,SVSEL,DAC 


data field 


OC 


BUFF 


7F 


WG, SVSEL,DAC 


data field 


OD 


BUFF 


7F 


WG,SVSEL,DAC 


data field 


OE 


BUFF, LAST 


7F 


WG, SVSEUDAC 


data field 


OF 


CHK 


1D 


WG, SVSEUDAC 


ECC 


10 


00 


02 


WG,JMPEN,DAC 


write splice 


11 


4E 


WIX 


WG, CWSEL 


pre-index gap 


12 


00 


STOP 


CWSEL 


stop at end of 
track 


START = 00, LOOP = 01 , SKIP = NOT USED 



TABLE 6-37. FORMAT TRACK EXAMPLE CONTROL STORE 



Line by line discussion of Format Track Example: 

00: This instruction just waits until the leading 
edge of index. No writing is occurring. If there is 
no index signal working on the drive, the CPU will 
have to timeout and issue an abort. The DAC bit 
is zero to select the checksum for the ID, as 
specified by the SRESET register. 

01 : This instruction is the standard 4E gap from 
index to the start of the first sector. This instruc- 
tion is also the intersector gap, because after the 
data field write splice on instruction 11 is written, 
the WD10C01 A will jump to this address specified 
by the LOOP register. 

02: This instruction is the PLL sync field for the ID 
field. The WG - CMPEN combination also marks 



the start of the CRC calculation starting with in- 
struction 03. 

03: This is the first address mark byte for the ID 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 

04: This is the second address mark byte, and is 
treated as simple immediate data for format pur- 
poses. 

05: This is the ID address and flag field. 

06: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. The end of this instruction 
also stops the checksum calculation. 
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07: ID write splice and data PLL sync field. This 
gap protects the end of the ID field from the start 
of the data field on later update write commands. 

08: Data PLL sync field. The WG - CMPEN com- 
bination also marks the start of the ECC calcula- 
tion starting with instruction 0A. The DAC bit is set 
here to select the data field checksum, and in this 
case it also causes a one byte prefetch from the 
buffer. 

09: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 

OA: This is the second address mark byte, and is 
treated as simple immediate data for format pur- 
poses. 

OB-OD: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require reordering the 
control store data (see above). The example 
shows a 512 byte sector. 

OE: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 

OF: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1 ) bytes. The end of this instruction also stops 
the checksum calculation. 

10: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 
is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 



addressed by the LOOP register, in this case 01. 
This happens only if SECCNT is not zero. If SEC- 
CNT is zero, the next control instruction is 11 . 

11: After the last sector, SECCNT is zero. After 
instruction 10 is done, the next instruction will be 
this one instead of instruction 01 (LOOP register). 
This instruction writes the 4E gap until index. 

12: The STOP bit causes the sequencer to shut 
down immediately and turn off all external signals 
(like WG, etc.). 

The CPU performs the FORMAT TRACK com- 
mand as follows: 

1 . After setting up the control store and ad- 
dress registers as defined above, write the 
total sectors per track to the SECCNT 
register. 

2. Write DXFER, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 

3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If DXFER goes true, update the ID 
write registers with the next ID field (when 
using non-consecutive, i.e., not 1:1 inter- 
leave). 

4. Repeat step 3 for all sectors on the track. 

5. After the last sector, wait for SEQSTP to be 
true, indicating the end of the command. 




11/19/91 



20-39 



WD10C01A 



PROGRAMMING REFERENCE 



6.6.4.2 Read Sector Example 


ADDRESS 


VALUE 


COUNT 


CONTROL 


NOTES 


00 


A1 


WIAM 


RG,CWSEL, RTY 


address mark 
search 


01 


FE 


00 


RG,CWSEL, RTY 


ID marker byte 


02 


ID 


02 


RG, SVSEL, 
CMPEN 


ID address 


03 


ID 


00 


RG, SVSEL 


ID flag 


04 


CHK 


01 


RG, SVSEL 


CRC 


05 


00 


03 


RTY 


allow ID retry 


06 


A1 


WDAM(1F) 


RG, CWSEL, 
DAC, FAIL 


address mark 
search 


07 


F8 


00 


RG, CWSEL, 
DAC, FAIL 


data marker byte 


08 


BUFF 


3F 


RG, SVSEL, DAC 


data field 


09 


BUFF 


3F 


RG, SVSEL, DAC 


data field 


0A 


BUFF 


3F 


RG, SVSEL, DAC 


data field 


OB 


BUFF, LAST 


3F 


RG,SVSEL,DAC 


data field 


OC 


CHK 


ID 


RG, SVSEL,DAC 


ECC 


OD 


00 


02 


JMPEN.DAC, 
FAIL 


end of sector 


OE 


00 


STOP 


WG, SVSEL, DAC 


stop at end of 
read 


START = 00, LOOP = 00, SKIP = NOT USED 



TABLE 6-38. READ SECTOR EXAMPLE CONTROL STORE 



Line by line discussion of Read Sector example: 

00: This is the first instruction of the read sector 
command. The WIAM bit tells the WD10C01A to 
search for an ID address mark byte. The 
WD10C01 A will not timeout, so the CPU will have 
to abort after some period of time, if necessary. 
The DAC bit is zero during the ID field to select 
the ID checksum. The RTY bit is set so that if a 
read error (in this case, no sync match after 
AMDET true) occurs, a retry will be performed. 

01: This tells the WD10C01A to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 



02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 
the incoming ID field. The incoming ID is also 
written to the ID read registers. 

03: This is the ID flag field. This control store 
instruction is separate from the ID address field 
because the flag byte is not compared with the ID 
write register. It is still written to the ID read 
register. 

04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 

05: This instruction is both a pad over the write 
splice and a check for an ID retry. The ID com- 
pare status and checksum error status are latched 
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and held, and the RTY bit is now set, allowing the 
checking of this status. An ID retry occurs if the ID 
did not match, or if there was a checksum error. 
The checksum error is latched into the IDERR bit 
for future reference. We waited until this instruc- 
tion to check for an error so that the ID read 
registers could be loaded with this ID field. 

06: The WDAM bit tells the WD10C01 A to look for 
the data address mark. The (1F) indicates the 
byte count that is loaded into the byte count. This 
value is the maximum number of byte times that 
the WD10C01A will look for the address mark. 
This prevents locking up on a subsequent data 
field address mark. An error here causes an im- 
mediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 

07: This is the data marker byte. The CMPEN bit 
indicates that the byte must compare exactly with 
the immediate data byte. An error here causes an 
immediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 

08-OA: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require rearranging the 
control store data (see above). The example 
shows a 256 byte sector. On ECC verify com- 
mands, change BUFF to NOXFER. On compare 
verify commands, set BUFF, the CMPEN bit in the 
control byte, and RCMP in the SEQCTL register. 

OB: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. LAST must be used for BUFF or NOXFER. 

0C: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. This instruction switches the check- 
sum shift register into check mode. 



0D: The purpose of this instruction is to turn off 
RG, resetting any external data decoder circuits. 
The JMPEN bit is also set in this instruction, 
meaning that the next instruction to be accessed 
will be the one addressed by the LOOP register, 
in this case 00. This happens only if the SECCNT 
register is not zero. If SECCNT is zero, the next 
instruction is 12. The FAIL bit is also set, causing 
the checksum status to be checked, and if there 
was an error, the command stops, with ECCERR 
set in the SEQCTL register. 

0E: After the last sector, the SECCNT register is 
zero. After instruction 0D is done, the next instruc- 
tion will be this one instead of instruction 00 
(LOOP register). This instruction stops the com- 
mand immediately. 

The CPU performs the READ SECTOR command 
as follows: 

1 . After setting up the control store and ad- 
dress registers as defined above, write the 
sector count to the SECCNT register to 
start the transfer. 

2. Write FAULT, IDFULL, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 

3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the value in the ID FIFO. If SEQSTP is 
true, make sure that no error occurred that 
must be serviced. Clear the status ser- 
viced. 
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6.6.4.3 Write Sector Example 


ADDRESS 


VALUE 


COUNT 


CONTROL 


NOTES 


00 


A1 


WIAM 


RG,CWSEL, RTY 


address mark 
search 


01 


FE 


00 


RG,CMPEN, RTY 


ID marker byte 


02 


ID 


02 


RG, SVSEL, 
CMPEN 


ID address 


03 


ID 


00 


RG, SVSEL 


ID flag 


04 


CHK 


01 


RG, SVSEL 


CRC 


05 


00 


02 


RTY 


wait past splice 


06 


00 


OB 


WG, CMPEN, 
DAC 


PLLsync 


07 


A1 


00 


WG, AM, DAC 


address mark 


08 


F8 


00 


WG, DAC 


data marker byte 


09 


BUFF 


FF 


WG, SVSEL, DAC 


data field 


0A 


BUFF 


FF 


WG, SVSEL, DAC 


data field 


OB 


BUFF 


FF 


WG, SVSEL,DAC 


data field 


OC 


BUFF, LAST 


FF 


WG, SVSEL, DAC 


data field 


OD 


CHK 


1D 


WG, SVSEL,DAC 


ECC 


OE 


00 


02 


WG,JMPEN,DAC 


write splice 


OF 


00 


STOP 


CW SEL 


stop at end of 
cmd 


START = 00, LOOP = 00, SKIP = NOT USED 



TABLE 6-39. WRITE SECTOR EXAMPLE CONTROL STORE 



Line by line discussion: 

00: This is the first instruction of the write sector 
command. The WIAM bit tells the WD10C01A to 
search for an ID address mark byte. The 
WD10C01A will not timeout, so the CPU will have 
to abort after it times out, if necessary. The DAC 
bit is zero during the ID field to select the ID 
checksum. The RTY bit is set so that if a read 
error (in this case, no sync match after AMDET 
true) occurs, a retry will be performed. 

01: This tells the WD10C01A to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 

02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 



the incoming ID field. The incoming ID is also 
written to the ID read registers. 

03: This is the ID flag field. This instruction is 
separate from the ID address field because the 
flag byte is not compared with the ID write 
register. It is still written to the ID read register. 

04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 

05: This instruction spaces over the ID field write 
splice to the start of the data field, protecting the 
ID checksum in the process. This instruction also 
performs a check for an ID retry. The ID compare 
status and checksum error status are latched and 
held, and the RTY bit is now set, allowing the 
checking of this status. An ID retry occurs if the ID 
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did not match, or if there was a checksum error. 
The checksum error is latched into the IDERR bit 
for future reference. 

06: Data PLL sync field. This instruction is the 
start of the update write sector data. The WG - 
CMPEN combination also marks the start of the 
ECC calculation starting with instruction 07. 

07: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 

08: This is the data marker byte, and is treated as 
simple immediate data for write sector purposes. 

09-0 A: These are the first three instructions that 
define the sector data field. The data field is split 
into four control instructions so that switching be- 
tween sector sizes will not require reordering the 
control store data (see above). The example 
shows a 1 024 byte sector. 

0B: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 

0C: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. The end of this instruction also stops 
the checksum calculation. 

0D: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 



is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 
addressed by the LOOP register, in this case 00. 
This happens only if the SECCNT register is not 
zero. If SECCNT is zero, the next control instruc- 
tion is 0E. 

0E: After the last sector, SECCNT is zero. After 
instruction 11 is done, the next instruction will be 
this one instead of instruction 00 (LOOP register). 
This instruction stops the command immediately. 

The CPU performs the WRITE SECTOR com- 
mand as follows: 

1 . After setting up the control store and ad- 
dress registers as defined above, write the 
sector count to the SECCNT register to 
start the transfer. 

2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 

3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 
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6.6.4.4 Read and Write Sector Example 

This example makes use of the SKIP register to 
merge the read and write sector operations into 
one control store program. Selection between 
read and write is performed solely by changing 



the contents of the SKIP register. The control 
store example shown in the table below is divided 
into the ID search, read data field, and write data 
field sections. 



ADDRESS 


VALUE 


COUNT 


CONTROL 


NOTES 


00 


A1 


WIAM 


RG,CWSEL, RTY 


address mark search 


01 


FE 


00 


RG.CMPEN, RTY 


ID marker byte 


02 


ID 


02 


RG, SVSEL, CMPEN 


ID address 


03 


ID 


00 


RG, SVSEL 


ID flag 


04 


CHK 


01 


RG, SVSEL 


CRC 


05 


00 


02 


SKPEN, RTY 


retry ID 


08 


00 


00 


00 


wait past splice 


09 


A1 


WDAM(1F) 


RG,CWSEL,DAC,FAIL 


address marker search 


0A 


F8 


00 


RG, SVSEL,DAC 


data marker byte 


0B 


BUFF 


3F 


RG, SVSEL,DAC 


data field 


OC 


BUFF 


3F 


RG, SVSEL,DAC 


data field 


0D 


BUFF 


3F 


RG, SVSEL,DAC 


data field 


0E 


BUFF, 
LAST 


3F 


RG,SVSEL,DAC 


data field 


OF 


CHK 


1D 


RG,SVSEL,DAC 


ECC 


10 


00 


02 


JMPEN,DAC, FAIL 


end of sector 


11 


00 


STOP 


CWSEL 


stop at end of read 


14 


00 


0B 


WG, CMPEN,DAC 


PLL sync 


15 


A1 


00 


WG, AM,DAC 


address mark 


16 


F8 


00 


WG, DAC 


data marker byte 


17 


BUFF 


FF 


WG, SVSEL,DAC 


data field 


18 


BUFF 


FF 


WG, SVSEL,DAC 


data field 


19 


BUFF 


FF 


WG, SVSEL,DAC 


data field 


1A 


BUFF, 
LAST 


FF 


WG, SVSEL,DAC 


data field 


1B 


CHK 


1D 


WG, SVSEL,DAC 


ECC 


1C 


00 


02 


WG,JMPEN,DAC 


write splice 


1D 


00 


STOP 


CW SEL 


stop at end of cmd 


START = 00, LOOP = 00, SKIP = 08 for read, 1 4 for write 



TABLE 6-40. READ AND WRITE SECTOR EXAMPLE CONTROL STORE 
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Line by line discussion of Read and Write ex- 
ample: 

00: This is the first instruction of the ID search. 
The WIAM bit tells the WD10C01A to search for 
an ID address mark byte. The WD10C01A will not 
timeout, so the CPU will have to abort after it 
times out, if necessary. The DAC bit is zero during 
the ID field to select the ID checksum. The RTY 
bit is set so that if a read error (in this case, no 
sync match after AMDET true) occurs, a retry will 
be performed. 

01: This tells the WD10C01A to verify the ID 
marker byte. If it does not compare exactly, an ID 
retry occurs (see below) because the RTY bit is 
set. 

02: This is the ID address field. The CMPEN bit 
causes a compare of the ID write registers with 
the incoming ID field. The incoming ID is also 
written to the ID read registers. 

03: This is the ID flag field. This instruction is 
separate from the ID address field because the 
flag byte is not compared with the ID write 
register. It is still written to the ID read register. 

04: ID CRC field. The count field is set to (2-1) 
bytes for the ID CRC. This instruction switches 
the checksum shift register into check mode. 

05: This instruction performs a check for an ID 
retry. The ID compare status and checksum error 
status are latched and held, and the RTY bit is 
now set, allowing the checking of this status. An 
ID retry occurs if the ID did not match, or if there 
was a checksum error. The checksum error is 
latched into the IDERR bit for future reference. 
Also, the SKPEN bit is set, meaning the next ad- 
dress (assuming no errors occurred) will be the 
value in the SKIP register, which is 08 for read 
sector, and 14 for write sector. 

READ DATA FIELD 

08: This instruction spaces over the ID field write 
splice to the start of the data field, protecting the 
ID checksum in the process. 

09: The WDAM bit tells the WD10C01Ato look for 
the data address mark. The (1F) indicates the 
byte count that is loaded into the byte count. This 
value is the maximum number of byte times that 
the WD10C01A will look for the address mark. 



This prevents locking up on a subsequent data 
field address mark. An error here causes an im- 
mediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 

0A: This is the data marker byte. The CMPEN bit 
indicates that the byte must compare exactly with 
the immediate data byte. An error here causes an 
immediate halt, with SYNCER set in the SEQCTL 
register, because the FAIL bit is set. 

0B-0D: These are the first three instructions that 
define the sector data field. The data field is split 
into four instructions so that switching between 
sector sizes will not require reordering the control 
store data (see above). The example shows a 256 
byte sector. On ECC verify commands, change 
BUFF to NOXFER. On compare verify com- 
mands, set BUFF, the CMPEN bit in the control 
byte, and RCMP in the SEQCTL register. 

0E: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. LAST must be used for BUFF or NOXFER. 

OF: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1) bytes. This instruction switches the check- 
sum shift register into check mode. 

10: The purpose of this instruction is to turn off 
RG, resetting any external data decoder circuits. 
The JMPEN bit is also set in this instruction, 
meaning that the next instruction to be accessed 
will be the one addressed by the LOOP register, 
in this case 00. This happens only if the SECCNT 
register is not zero. If SECCNT is zero, the next 
control instruction is 11. The FAIL bit is also set, 
causing the checksum status to be checked, and 
if there was an error, the command stops, with 
ECCERR set in the SEQCTL register. 

11: After the last sector, the SECCNT register is 
zero. After instruction 10 is done, the next instruc- 
tion will be this one instead of instruction 00 
(LOOP register). This instruction stops the com- 
mand immediately. 

WRITE DATA FIELD 

14: Data PLL sync field. This instruction is the 
start of the update write sector data. The WG - 
CMPEN combination also marks the start of the 
ECC calculation starting with instruction 15. 
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15: This is the first address mark byte for the data 
field. The AM bit generates AMENA with the AMC 
register, suppressing the clock bit in the A1 byte. 

16: This is the data marker byte, and is treated as 
simple immediate data for write sector purposes. 

17-19: These are the first three instructions that 
define the sector data field. The data field is split 
into four instructions so that switching between 
sector sizes will not require reordering the control 
store data (see above). The example shows a 
1024 byte sector. 

1 A: The last instruction of the data field marks the 
end of the data field using the LAST bit set with 
BUFF. 

1B: Data ECC field. ECC degree six with inter- 
leave factor of five is used, the count field is set to 
(30-1 ) bytes. The end of this instruction also stops 
the checksum calculation. 

1C: Data field write splice. This instruction pads 
the end of the data field, making sure that the 
checksum is not lost by the drive. The JMPEN bit 
is also set in this instruction, meaning that the 
next instruction to be accessed will be the one 
addressed by the LOOP register, in this case 00. 
This happens only if the SECCNT register is not 
zero. If SECCNT is zero, the next control instruc- 
tion is 1D. 

ID-" After the last sector, SECCNT is zero. After 
instruction 1C is done, the next instruction will be 
this one instead of instruction 00 (LOOP register). 
This instruction stops the command immediately. 

The CPU performs the READ SECTOR command 
as follows: 

1 . After setting up the control store and ad- 
dress registers as defined above, write 06 
to the SKIP register, and then write the 
sector count to the SECCNT register to 
start the transfer. 

2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 

3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 



true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 

The CPU performs the WRITE SECTOR com- 
mand as follows: 

1 . After setting up the control store and ad- 
dress registers as defined above, write OF 
to the SKIP register, and then write the 
sector count to the SECCNT register to 
start the transfer. 

2. Write IDFULL, FAULT, and SEQSTP true 
to the SISR register to clear those status 
bits, and to the SIMR register to enable 
them. 

3. Wait until GINT is true with a timeout in 
case INDEX is not present on the inter- 
face. Check FAULT for error, and abort if 
true. If IDFULL is true, perform any checks 
on the data in the ID FIFO. If SEQSTP is 
true, check to see if an error occurred that 
must be serviced. Clear the status ser- 
viced. 



6.6.5 ID Retry and Error Conditions 

The WD10C01A manages errors by using the 
RTY and FAIL bits in the control store error control 
byte. These bits tell the WD10C01A when to 
check its internal error status bits, and what to do 
about the error. All internal status bits in the 
WD10C01A are held in their error state until reset 
by a retry, or by writing to the START register. 

If an error occurs when or before the RTY bit is 
set, an ID retry is performed. The LOOP register 
address will be loaded into the control store ad- 
dress register, restarting the sector. Also, the RG 
signal is switched false for one whole byte time to 
reset external decoders/PLLs. If the control store 
instruction at the LOOP address does not specify 
that RG is true, then it will stay false. 

If an error occurs when or before the FAIL bit is 
set, an immediate abort of the command occurs 
when FAIL goes true. The appropriate error status 
bit(s) are set, and the sequencer stops. 
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The following list summarizes the read error con- 
ditions of the WD1 0C01 A: 

1 . When executing a WIAM or WDAM opera- 
tion, and the AMDET signal goes true, but 
the sync byte does not match within the 
sixteen bit timeout period. SYNCER will 
be set true if a halt is commanded (FAIL 
set). 

2. When searching for a simple byte sync 
byte, and the count in the control store 
count field is exhausted. SYNCER will be 
set true if a halt is commanded (FAIL set). 

3. Once byte sync is established, any read 
compare operations (CMPEN bit set) that 
fail. In the case of immediate data, this 
handles the ST412 second address mark 
byte (FE or F8) and the SYNCER bit will 
be true if a halt is commanded (FAIL set). 
In all other cases (i.e., buffer or ID data), 
the CMPERR bit is be true if a halt is com- 
manded (FAIL set). 

4. Any checksum error. This error status is 
retained by the IDERR bit in the SEQCTL 
register if a retry is commanded (RTY set) 
until the next ID field starts. The ECCERR 
bit is set if an abort was commanded (FAIL 
set). In this case, the checksum shift 
register contains the correction syndrome. 
The register ECCS shows the additional 
ECC status. 

5. When executing a WDAM operation, if the 
AMDET signal does not go true, and the 
count in the control store count field is ex- 
hausted. SYNCER will be set true if a halt 
is commanded (FAIL set). 



6.6.6 Error Recovery 

When a read error occurs that causes a halt of the 
command before it is completed, certain steps 
must be performed to recover from that error. 
When the sequencer stops, the following condi- 
tions are in effect: 

1. The SECCNT register contains a 
remainder. If the error is an ID error or a 
sync error (SYNCER set), this is the num- 
ber of sectors to read including the one in 
error. Any other error gives the number of 
sectors to read after the one in error. 

2. The ID set registers are set to an ID field. If 
the error is a sync error, this is the sector 
address of the one in error. Any other error 
gives the sector address following the one 
in error. In general, any error that is 
detected after the data field transfer starts 
(DXF went true, see the SEQSTS register) 
will cause SECCNT and the ID write 
registers to be set for the sector following 
the one in error. 

3. The SEQCTL read bits define the error. If 
ECCERR is set, then the error is a check- 
sum error. If CMPERR is set, the error is a 
verify or second address mark byte error. 
If SYNCER is set, the error is a byte sync 
error. 

4. The internal checksum register may con- 
tain a correction syndrome, depending on 
the type of error. 

The SECCNT contains a non-zero remainder. 
SECCNT is inhibited from restarting the sequen- 
cer by the latched error status. In order to restart 
for retry or continuing, the START register must 
be written with the starting control store address. 
This immediately clears any error status 
(SEQCTL read bits), and if the SECCNT register 
is still non-zero, will cause the sequencer to start. 
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6.6.7 Error Correction 

The Reed-Solomon ECC Implemented in the 
WD10C01A can correct up to 2 error bytes (de- 
gree 5) and up to 3 error bytes (degree 6) per 
interleave. Depending bn the interleave factor 
being used, it can correct up to 30 bytes of error 
within a sector. 

During read operations, the device produces com- 
posite syndromes. These syndromes are used by 
the error correction routine (microprocessor) to 
calculate the error location and error value. The 
microprocessor responses to the SEQSTP inter- 
rupt by first reading the SISR and the ECCS 
registers to determine the type of failure. If the 
EERR bit in the ECCS is set, the microprocessor 
determines which interleaves are in error by read- 



ing the status bits I0E-I4E in the ECCS. The 
microprocessor then start reading the SPORT 
register to transfer the syndromes. The 
WD10C01A automatically transfer the syndromes 
from the lowest interleave number. The highest 
byte is transferred first. The microprocessor has 
to read the SPORT register five times for degree 
5 and six times for degree 6 to complete the 
syndrome transfer of an interleave. After all 
syndromes of the interleave are transferred, the 
microprocessor must reset the corresponding 
error status bit in the ECCS by writing a into that 
bit. The microprocessor can then continue reading 
the syndromes of the next interleave. 
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7.0 DC ELECTRICAL SPECIFICATIONS 

7.1 MAXIMUM RATINGS 



Ambient temperature 


0°C to 70°C 


Storage temperature 


-65° C to 150° C 


Voltage on any pin 
with respect to Vss 


-0.3 to Vdd+0.3 Volts 


Voltage on Vdd with 
respect to Vss 


7 Volts 


Leakage current 


±10 uA 


Power dissipation 


1000 mW 
at X1 =32 MHz, 
RRCLK=27 MHz, 
0°C, all outputs open 


Input Static 
Discharge Protection 


2000 V pin to pin 



NOTE 

Stresses above those listed under Maximum 
Ratings may cause permanent damage to the 
device. This is a stress rating only and functional 
operation of the device at these or any other con- 
ditions above those indicated in the operational 
section of the specification is not implied. Ex- 
posure to absolute maximum rating conditions for 
extended periods may affect product reliability. 



7.2 STANDARD TEST CONDITIONS 

The characteristics below apply for the following 
standard test conditions, unless otherwise noted. 
All voltages are referenced to Vss (0V Ground). 
Positive current flows into the referenced pin. 



Operating temperature range 


0° to 70° C 


Vdd supply voltage with 
respect to Vss 


+5 Volts ± 
0.5 V 


Vss 


Volts 


Latch-up current (min) 


±40 mA 


Operating humidity range 


20 to 95% 


X1 input operating frequency 
with crystal 


32 MHz(max) 
8 MHz (min) 


X1 input operating frequency 
with TTL source 


25 MHz(max) 
— MHz (min) 
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7.3 DC CHARACTERISTICS 


SYMBOL 


PARAMETER 


MIN 


MAX 


UNITS 


CONDITIONS 


VlH 


Input High Voltage 


2.0 


— 


V 


Vdd =5V±5% 


VlL 


Input Low Voltage 


— 


0.8 


V 


Vdd =5V±5% 


llH 


Input High Current 


— 


600 


HA 


Vil = 0.8V 


IlL 


Input Low Current 


— 


-600 


HA 


Vih = 2.0V 


VOH 


Output High Voltage 


2.4 


— 


V 


*, Ioh = -400 \iA 


Vol 


Output Low Voltage 


— . 


0.40 


V 


*, Iol = 2 mA 


VOH 


Output High Voltage 


Vdd-0.5 


— 


V 


**,Ioh = -800 (iA 


Vol 


Output Low Voltage 


— 


0.40 


V 


**, Iol = 4 mA 


Voh 


Output High Voltage 


2.4 


— 


V 


***,Ioh = -2.5 mA 


Vol 


Output Low Voltage 


— 


0.40 


V 


****, Iol =6 mA 


Ci 


Input Capacitance 


— 


10 


PF 


all inputs 


Co 


Output Capacitance 


— 


50 


PF 


All outputs except: D0-D7, 
BMD0-BMD7,BMP, OSC, and 
CPUCLK 


Co 


Output Capacitance 


— 


100 


PF 


Outputs D0-D7,BMD0-BMD7, 
and BMP 


Co 


Output Capacitance 


— 


100 


PF 


Outputs OSC and CPUCLK 


Ice 


Supply Current 


— 


200 


mA 


60 mA (typical); X1=32MHz, 
RRCLK=27MHz, 0°C, all out- 
puts open, Vdd=5V 



TABLE 7-1 . DC CHARACTERISTICS 



NOTES: 

Ta = 0°C (32°F) to 70°C (158°F), 
Vdd = +5V±5% 

* Output Voltages (all outputs except X2, 
CPUCLK, OSC, D0-D7), see t 

** Output Voltages (CPUCLK and OSC only), 
seef 

***Output Voltages (D0-D7), see t 

****Output Voltages (D0-D7JNT Logic 0) 

t Even under worst case AC transient switching 
conditions Vol = 0.8V shall not be exceeded on 
any output pin at any time. 
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8.0 AC OPERATING CHARACTERISTICS 

The following notes apply to all of the parameters 
presented in this section: 

1 . All unit are in nanoseconds 

2. These timing relationships assume the maxi- 
mum capacitive loading for both inputs and out- 
puts, Vdd = 4.50 volts to 5.50 volts. 

3. Temperature = 0°C to 70°C. 

4. All timing is measured between 0.8 volts logic 
low and 2.0 volts logic high, unless otherwise 
noted. 



8.1 OSC AND CPUCLK TIMING 




FIGURE 8-1. TTL SOURCE X1 CLOCK INPUT 







t 


4 








OSC _ 








^ / 


\ 


y 




'8 




u 




'8 








*6 











FIGURE 8-2. OSC OUTPUT 
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FIGURE 8-3. CPUCLK OUTPUT 



The following table summarizes the relationship 
between the clock at X1 and the resultant outputs 
at OSC and CPUCLK. OSCDIV and CPUDIV are 
control bits in the RESET register that determine 
how the X1 clock is divided to produce OSC and 
CPUCLK. See the programming section for more 
information. 



OSCDIV 


CLKDIV 


OSC 


CPUCLK 








X1/2 


X1/6 





1 


X1/2 


X1/4 


1 





X1/1 


X1/3 


1 


1 


X1/1 


X1/2 
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No. 


DESCRIPTION 


MIN 


MAX 


UNITS 


ti 


TTL source X1 high or low(*1) 


13 




ns 


t2 


TTL source X1 cycle time 


40 




ns 


t3 


TTL source X1 rise or fall time (*1 ) 




5 


ns 


t4 


OSC high or low when: (*2) 




— 


— 




X1/1 crystal (*3) 


10 


— 


ns 




X1/2 crystal (*3) 


27 


33 


ns 




X1/1 TTL source (*5) 


16 


24 


ns 




X1/2 TTL source (*4) 


36 


44 


ns 


t5 


CPUCLK high or low when: (*2) 


— 


— 


— 




X1/2 crystal (*3) 


27 


33 


ns 




X1/3 crystal (*3) 


36 


54 


ns 




X1/4 crystal (*3) 


54 


66 


ns 




X1/6 crystal (*3) 


81 


99 


ns 




X1/2 TTL source (*4) 


36 


44 


ns 




X1/3 TTL source (*5) 


48 


72 


ns 




X1/4 TTL source (*4) 


72 


88 


ns 




X1/6 TTL source (*4) 


108 


132 


ns 


t6 


OSC cycle time when: 


— 


— 


— 




X1/1 crystal (*3) 


30 


125 


ns 




X1/2 crystal (*3) 


60 


250 


ns 




X1/1 TTL source (*4) 


40 


— 


ns 




X1/2 TTL source (*4) 


80 


— 


ns 


t7 


CPUCLK cycle time when: 


— 


.._ 


— 




X1/2 crystal (*3) 


60 


250 


ns 




X1/3 crystal (*3) 


90 


375 


ns 




X1/4 crystal (*3) 


120 


500 


ns 




X1/6 crystal (*3) 


180 


750 


ns 




X1/2 TTL source (*4) 


80 


— 


ns 




X1/3 TTL source (*4) 


120 


„. 


ns 




X1/4 TTL source (*4) 


160 


._. 


ns 




X1/6 TTL source (*4) 


240 


— 


ns 


t8 


CPUCLK and OSC rise or fall time (*2) 


„_ 


5 


ns 



TABLE 8-1. OSC AND CPUCLK TIMING PARAMETERS 



NOTES: 

*1)Times are measured relative to Vih and 
Vil. 

*2)High and low times are measured relative 
to the midpoints between Vol and Voh. 
Rise and fall times are measured between 
Voh and Vol. 



*3)Assumes 33.3 MHz crystal across X1 and 
X2 for min times, 8.0 MHz crystal for max 
times. 

*4)Assumes 25.0 MHz TTL source to X1 . 

*5)Assumes 25.0 MHz TTL source to X1, 
50/50 duty cycle. 



&. 
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8.2 CPU INTERFACE TIMING 
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FIGURE 8-4. MICROPROCESSOR RD* TIMING (RD* CONTROLLED) 
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FIGURE 8-5. MICROPROCESSOR RD* TIMING (CS* CONTROLLED) 
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FIGURE 8-6. MICROPROCESSOR WR* TIMING (WR* CONTROLLED) 
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FIGURE 8-7. MICROPROCESSOR WR* TIMING (CS* CONTROLLED) 
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FIGURE 8-8. RESET TIMING 
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FIGURE 8-9. EXTERNALLY GENERATED INTERRUPT TIMING 
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No. 


DESCRIPTION 


MIN 


MAX 


UNITS 


t20 


address valid to RE or WE (*3) 


20 




ns 


t21 


RE pulse width (*3) 


100 




ns 


t22 


RE or WE to address change (*3) 







ns 


t23 


RE true to data valid (*3) 


... 


95 


ns 


t24 


RE false to data hold (*3) 


20 


60 


ns 


t25 


input port setup to RE true (*1)(*3) 


80 


... 


ns 


t26 


WE pulse width (*3) 


100 


— 


ns 


t27 


data setup to WE false (*3) 


80 




ns 


t28 


WEfelse to data hold (*3) 







ns 


t29 


WE false to output change (*2)(*3) 


— 


80 


ns 


t30 


RST pulse width 


100 


— 


ns 


t31 


RST true to stable outputs 


— 


150 


ns 


t32 


DRVFLT or COMPLT pulse width 


100 


— 


ns 


t33 


DRVFLT or COMPLT high to INT low 


— 


150 


ns 



NOTES: 



TABLE 8-2. CPU INTERFACE TIMING PARAMETERS 



*1)lnputs are: PZO-5, PY0-3 when defined as 
inputs, and AMDET when being used as a 
simple input pin. 

*2)Outputs are: PXO-7, and PYO-3 when 
defined as outputs. 

*3)RE = RDorCS: 
WE = WR or CS 
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8.3 BUFFER INTERFACE TIMING 

(Data is coming out of the WD1 0C01 A) 

REQTIM=1 in RESET register. (REQA true when internal data register is full.) 
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FIGURE 8-10. ASYNCHRONOUS MODE DATA BUS WRITE TIMING (1) 



REQTIM=0 in RESET register. (REQA true one bit time before internal data register is full. Note that the 
cycles overlap by one bit time.) 
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FIGURE 8-11. ASYNCHRONOUS MODE DATA BUS READ TIMING (0) 
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(Data is going into the WD10C01 A) 

REQTIM=1 in RESET register. (REQA true when internal data register is empty.) 
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FIGURE 8-12. ASYNCHRONOUS MODE DATA BUS READ TIMING (1) 



REQTIM=0 in RESET register. (REQA true one bit time before internal data register is empty. Note that 
the cycles overlap by one bit time.) 
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FIGURE 8-13. ASYNCHRONOUS MODE DATA BUS WRITE TIMING (0) 
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No. 


DESCRIPTION 


MIN 


MAX 


UNITS 


t40 


DMA (REQA) cycle time (*1) 




8*Tcyc 


ns 


t41 


RRCLK true to REQA true 




40 


ns 


t42 


ACKA false to RRCLK true 


20 




ns 


t43 


REQA true to ACKA false: (*1 ) 
REQTIM=0 
REQTIM=1 




9*T C yc-t41-t42 
8*T C yc-t41-t42 


ns 


t44 


ACKA active low 


100 


— 


ns 


t45 


ACKA true to data valid 




60 


ns 


t46 


ACKA false to data hold 


10 


60 


ns 


t47 


data setup to ACKA* false 


35 




ns 


t48 


ACKA false to data hold 


5 




ns 


t49 


ACKA true to REQA false 




35 


ns 



TABLE 8-3. BUFFER INTERFACE TIMING PARAMETERS 



NOTES: 

*1)T cyc is the RRCLK cycle time used. 
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8.4 SERIAL DATA TIMING 
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FIGURE 8-14. NRZ DATA INPUT TIMING 
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FIGURE 8-15. NRZ DATA OUTPUT TIMING 
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No. 


DESCRIPTION 


MIN 


MAX 


UNITS 


t60 


RRCLK cycle time 


37 




ns 


t61 


RRCLKlow (*1) 


14 




ns 


t62 


RRCLK high (*1) 


14 




ns 


t63 


NRZI setup to RRCLK high 


10 




ns 


t64 


RRCLK high to NRZI hold 


10 




ns 


t65 


RRCLK high to new control out (*3) 




30 


ns 


t66 


AMDET setup to RRCLK high (*4) 


10 




ns 


t67 


RRCLK high to AMDET hold (*4) 


10 




ns 


t68 


asynchronous input width 


2*Tcyc 




ns 


t70 


WRCLK high (*2) (*6) 

(*2)(*6)(*7) 


Trio-6.0 
Trio-5.0 




ns 


t71 


WRCLK low (*2) (*6) 

(*2) (*6) (*7) 


Trhi-6.0 
Trhi-5.0 




ns 


t72 


WRCLK low to NRZO change(*6) 

(*6) (*7) 


-3.5 
-2.75 


3.5 
2.75 


ns 


t73 


NRZO setup to WRCLK high(*6) 

(*6)(*7) 


Trhi-9.5 
Trhi-8.75 




ns 


t74 


WRCLK high to NRZO hold (*6) 

(*6) (*7) 


Trio-9.5 
Trio-8.75 




ns 


t75 


RRCLK high to NRZO change 




30 


ns 



TABLE 8-4. SERIAL DATA TIMING PARAMETERS 



NOTES: 



*1)High and low times measured relative to 
Vih and Vii_. 

*2)T r io and T r hi are the clock low and clock 
high (respectively) for the RRCLK input 
used. T C yc is RRCLK cycle time used. 

*3)Control outputs are: SEQOUT, WG, RG, 
andAMENA. 



*5)Asynchronous inputs are: INDEX, SEC- 
TOR, and AMDET when it is supplied from 
an asynchronous source. 

*6)Where the RRCLK input is driven from 
0.4V (Vil) to 2.4V (Vih). 

*7)The specification with reduced load 
capacitance of 25 pF. 



*4)When AMDET is supplied from a 
synchronous source. 
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A.O WD10C01 A PROGRAMMER'S BENCH REFERENCE (PBR) 

A.1 ADDRESS BIT TABLES 

The following is a set of bit tables. 



ADDR 


NAME 


DIR 


SIZE 


00 


SRESET 


W 


6-0 


01 


SISR 


R/W 


7-0 


02 


SIMR 


R/W 


7-0 


03 


SEQSTS/PYC 


R/W 


7-0/ 
3-0 


04 


CSERR 


R/W 


3-0 


05 


CSCTL 


R/W 


7-0 


06 


CSVAL 


R/W 


7-2; 
7-0 


07 


CSCNT 


R/W 


7-4, 
0;7-0 


08 


PORTX 


R/W 


7-0 


09 


PORTY 


R/W 


3-0 


0A 


PORTZ/AMC 


R/W 


5-0/ 
7-0 


0B 


SEQCTL 


R/W 


5-0 


OC 


START 


R/W 


4-0 


OD 


LOOP 


W 


4-0 


OE 


ECCCTL 


W 


5-1 


OF 


SECCNT 


R/W 


7-0 


10 


ECCP 


R/W 


3-0 


11 


ECCS 


R/W 


4-0 


12 


SPORT 


R 


7-0 


13 


Reserved 




7-0 


14 


Reserved 




7-0 


15 


Reserved 




7-0 


16 


do not use - test only 


17 


SKIP 


W 


4-0 


18 


I DO 


R/W 


7-0 


19 


ID1 


R/W 


7-0 


1A 


ID2 


R/W 


7-0 


1B 


ID3 


R/W 


7-0 


1C 


ID4 


R/W 


7-0 


1D 


ID5 


R/W 


7-0 


1E 


ID6 


R/W 


7-0 


1F 


ID7 


R/W 


7-0 



SRESET(OO) 


Bit 


Write 


7 


CLKDIV 


6 


OSCDIV 


5 




4 




3 




2 


REQTIM 


1 


ID3$4 





SRST 




SISR(01)ANDSIMR(02) 


Bit 


Read/Write 


7 


GINT 


6 


IDFULL 


5 


DXFER 


4 


COMPLT 


3 


SEQSTP 


2 


SECEND 


1 


SM$IX 





FAULT 




SEQSTS(03) 


Bit 


Read 


7 


DATFLD 


6 


ECCEN 


5 


LAST 


4 


ID 


3 


CHK 


2 


WAIT 


1 


AMDET 





SEQOUT 



TRUE = 1 FOR ALL BITS 
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PYC(03) 


Bit 


Write 


7 




6 




5 




4 




3 


PY30UT 


2 


PY20UT 


1 


PY10UT 





PYOOUT 




CSERR(04) 


Bit 


Read/Write 


7 




6 




5 




4 




3 


FAIL 


2 


RTY 


1 


DAC 





SEQOUT 




CSCTL(05) 


Bit 


Write 


7 


SVSEL 


6 


CWSEL 


5 


WG 


4 


RG 


3 


AM 


2 


CMPEN 


1 


SKPEN 





JMPEN 



CSVAL(06) 


Bit 


Read/Write 


7 


BUFF 


6 


NOXFER 


5 


LAST 


4 


ID 


3 


CHK 


2 




1 










CSCNT(07) 


Bit 


Read/Write 


7 


WDAM (COUNT) 


6 


WIAM 


5 


WIX 


4 


WSM 


3 




2 




1 







STOP 



SEQCTL(OB) 


Bit 


Read 


Write 


7 




RGERLY 


6 






5 


ECCERR 




4 


IDERR 




3 


PTYERR 


IXMASK 


2 


SYNCER 


SMMASK 


1 


CMPERR 


RCMP 







KILL 
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ECCCTL(OE) 


Bit 


Write 


7 




6 




5 


ECCCLR 


4 


CRCSET 


3 


CRCNIT 


2 


IGNERR 


1 


DISPTY 









ECCP(10) 


Bit 


Read/Write 


7 




6 




5 




4 




3 


SYNCCRC 


2 


SYNCECC 


1 


DEG6/5 





IFS5/3 



ECCS(11) 




Bit 


Read 


Write 


7 






6 


EERR 




5 


CERR 




4 


I4E 


I4E 


3 


I3E 


I3E 


2 


I2E 


I2E 


1 


HE 


ME 





IOE 


IOE 
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B.O RESET CONDITIONS 



The following list defines what is reset when RST 
is asserted on the WD10C01A, or the CPU sets 
the internal reset bit (SRST in SRESET register): 

• SRST bit in SRESET is left set, and must be 
cleared by the CPU to take the WD10C01 A 
out of the reset state 

• interrupts are disabled 

• PYO-3 are set to input 

• BMD0-7,P are disabled 

• OSCissettoX1/2 

• CPUCLKissettoX1/6 

• command sequencer stops 

The following CPU registers are reset to zero: 

• PORTX 

• PORT Y CONFIGURATION 

• SECTOR COUNTER 

• INTERRUPT MASK REGISTER 

• SRESET REGISTER (except SRST) 

• ECCP except SYNCCRC and SYNCECC, 
which are initialized to one's 

• ECCS 

• SPORT 

• KILL and RGERLY bits in SEQCTL register 



The following outputs are reset to zero: 

• PXO-7 

• SEQOUT 

• AMENA 

• RG 

• WG 

• NRZO 

• REQA 

The following error status bits are reset to zero: 

• IDERR 

• PTYERR 
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CO CRYSTAL OSCILLATOR APPLICATIONS 

For applications that use the internal oscillator 
capability of the WD10C01A, a series resonant 
crystal must be used. This crystal must meet the 
following internal specifications: 

CS = 7 pf MAX 

RS = 30 ohms MAX 

The oscillator also requires bypass capacitors, as 
shown in the following diagram:The following 
table lists values for C1 and C2 for several typical 
crystal frequencies. The capacitor tolerances are 
±10%. Values for intermediate frequencies (not 
listed in the table) may be extrapolated. 



FREQ (MHz) 


C1 (pf) 


C2(pf) 


8 


180 


100 


10 


180 


68 


12 


150 


47 


14 


120 


56 


16 


82 


56 


20 


82 


33 


24 


56 


27 


25 


56 


22 


30 


39 


12 


32 


33 


12 



Pin 37 [x1] 



Crystal 



Pin 38 [x2] 



C2 



C1 



FIGURE C-1. OSCILLATOR WITH CAPACITORS 
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D.O 


PIN/SIGNAL SUMMARY 


PIN 


SIGNAL 


I/O 


FUNCTION 


1 


BMD7 


I/O 


Buffer 


2 


BMD6 


I/O 


Buffer 


3 


BMD5 


I/O 


Buffer 


4 


BMD4 


I/O 


Buffer 


5 


BMD3 


I/O 


Buffer 


6 


BMD2 


I/O 


Buffer 


7 


BMD1 


I/O 


Buffer 


8 


BMDO 


I/O 


Buffer 


9 


VSS 


I 


Ground 


10 


CS 


I 


CPU Interface 


11 


DBO 


I/O 


CPU Interface 


12 


DBO 


I/O 


CPU Interface 


13 


DBO 


I/O 


CPU Interface 


14 


DBO 


I/O 


CPU Interface 


15 


DBO 


I/O 


CPU Interface 


16 


DBO 


I/O 


CPU Interface 


17 


DBO 


I/O 


CPU Interface 


18 


DBO 


I/O 


CPU Interface 


19 


RD 


I 


CPU Interface 


20 


WR 


I 


CPU Interface 


21 


A4 


I 


CPU Interface 


22 


A3 


I 


CPU Interface 


23 


A2 


I 


CPU Interface 


24 


A1 


I 


CPU Interface 


25 


AO 


I 


CPU Interface 


26 


VDD 


I 


+5 Volts 


27 


INT 





CPU Interface 


28 


SECTOR 


I 


Disk Control 


29 


INDEX 


I 


Disk Control 


30 


AMDET 


I 


Disk Data 


31 


AMENA 





Disk Data 


32 


SEQOUT 





Disk Data 


33 


OSC 





CPU Interface 


34 


DRVFLT 


I 


Disk Control 


35 


COMPLT 


I 


Disk Control 



PIN 


SIGNAL 


I/O 


FUNCTION 


36 


CPUCLK 





CPU Interface 


37 


X1 


I 


CPU Interface 


38 


X2 





CPU Interface 


39 


PZ5 


I 


Disk Control 


40 


PZ4 


I 


Disk Control 


41 


PZ3 


I 


Disk Control 


42 


PZ2 


I 


Disk Control 


43 


VSS 


I 


Ground 


44 


PZ1 


I 


Disk Control 


45 


PZ0 


I 


Disk Control 


46 


PY3 


i,o 


Disk Control 


47 


PY2 


l,0 


Disk Control 


48 


PY1 


i,o 


Disk Control 


49 


PY0 


i,o 


Disk Control 


50 


PX7 





Disk Control 


51 


PX6 





Disk Control 


52 


PX5 





Disk Control 


53 


PX4 





Disk Control 


54 


PX3 





Disk Control 


55 


PX2 





Disk Control 


56 


PX1 





Disk Control 


57 


PXO 





Disk Control 


58 


WG 





Disk Data 


59 


RG 





Disk Data 


60 


VDD 


I 


+5 Volts 


61 


RST* 


I 


CPU Interface 


62 


WRCLK 





Disk Data 


63 


NRZO 





Disk Data 


64 


RRCLK 


I 


Disk Data 


65 


NRZI 


I 


Disk Data 


66 


REQA 





Buffer 


67 


ACKA 


I 


Buffer 


68 


DBP 


I/O 


Buffer 
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E.O DIFFERENCES BETWEEN WD10C00 AND WD10C01 A 



E.1 ERROR CORRECTION AND 
DETECTION 

The computer-generated-code ECC in WD10C00 
was replaced with the Reed-Solomon ECC in 
WD10C01A. Six registers (ECC[0:5]) which define 
the masks for ECC polynomials in WD10C00 
were taken out. The new ECCP, ECCS, SPORT 
registers facilitate the configuration parameters, 
operation status and the syndrome access for the 
new RS encoder/decoder. 



E.2 SRESET REGISTER 

The control bits IDCHK, DCHK, ECCSIZ bits of 
the WD10C00 are removed. By default, data field 
is covered by RS-ECC, and ID Field is covered by 
CCITT-CRC with g(x)= X 16 + X 12 + X 5 + 1. 



specifications with reduced loading capacitance of 
25 pF. 



E.5 PIN NAME 

The name of the microprocessor data bus and the 
DMA data bus are changed to reflect the name on 
the circuit diagrams. The pin order and the func- 
tions are exactly the same as before. 



WD10C00 


WD10C01A 


DB0-DB7 


BMD0-BMD7 


DBP 


BMDP 


D0-D7 


DB0-DB7 




E.3 ECCCTL REGISTER 

The ECCINL, ECCSHT, ECCINM bits of the 
WD10C00 are removed. The control bit ECCSET 
is renamed to CRCSET, bit ECCNIT is renamed 
to CRCNIT These bits affect only the CRC shift 
registers, the RS-ECC shift registers are be 
default reset to zero. The control bit DISCHK of 
WD10C00 is changed into IGNERR. Its function is 
still the same. 



E.4 TIMING 

The ti ming U7 (data setup time on the BMD bus 
before ACKA goes inactive) is changed from 30 
ns to 35 ns; t70, tyi, t72, t73 and t74 have additional 



E.6 PARITY ERROR HANDLING 

WD10C00 will latch the parity error condition into 
the SEQCTL register and the operation will con- 
tinue normally. WD10C01A will stop at the end of 
the current CS instruction if the FAIL bit is set to 
one. The WG output is also deasserted. 



E.7 SEQCTL REGISTER 

Bit 6 and bit in the SEQCTL register are unused 
in the WD10C00 and in the WD10C01A. These 
bits are read-only type and are set to one in the 
WD10C00; in the WD10C01A, these bits are set 
to zero. 
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